返回技能列表

form-strategy

rampstackco
更新于 2 days ago
5 次查看
239
27
239
在 GitHub 上查看
其他design

关于

The `form-strategy` skill helps developers design, audit, and optimize forms to maximize conversion, implement robust validation, and prevent spam. It provides guidance for any form type, from signup to checkout, and is triggered by issues like low completion rates or high spam volume. Its stack-agnostic advice covers planning logic, choosing tooling, and ensuring clean system integration.

快速安装

Claude Code

推荐
主要方式
npx skills add rampstackco/claude-skills -a claude-code
插件命令备选方式
/plugin add https://github.com/rampstackco/claude-skills
Git 克隆备选方式
git clone https://github.com/rampstackco/claude-skills.git ~/.claude/skills/form-strategy

在 Claude Code 中复制并粘贴此命令以安装该技能

技能文档

Form Strategy

Forms are where intent becomes action. Design them well or lose conversions, frustrate users, and drown in spam. Stack-agnostic.


When to use

  • Designing or redesigning a form
  • Conversion is dropping on a key form
  • Spam volume is overwhelming the inbox or database
  • Auditing forms across a site
  • Planning validation logic
  • Choosing form tooling (form service, custom build, no-code)
  • Integrating forms with CRM, email, or other downstream systems
  • Multi-step form decisions

When NOT to use

  • Generic conversion optimization (use cro-optimization)
  • The copy on the form (use landing-page-copy)
  • Backend handling beyond form-specific concerns (use frontend-component-build, code-review-web)
  • General accessibility (use accessibility-audit)

Required inputs

  • The form's purpose (what action, what outcome)
  • Current form (URL, screenshot, or fields)
  • Current performance (completion rate, spam rate, conversion to next step)
  • Downstream system (where submissions go: CRM, email, database, support tool)
  • Business context (volume, urgency of leads, cost of false vs missed signups)

The framework: 5 dimensions

Every form decision falls into one of these dimensions.

Dimension 1: Field strategy

The biggest lever. Every additional field reduces conversion.

Questions to ask for each field:

  • Is this required to deliver value to the user?
  • Is this required to deliver value to the business?
  • Can it be inferred from another source (email domain, behavior, context)?
  • Can it be asked later (after first contact, on second visit, on settings page)?

Default rule: ask for the minimum to make the next step happen. Everything else later.

For a B2B contact form: name and email get you started. Phone, company size, role are nice-to-haves that often hurt conversion more than they help qualification.

For a checkout: country, postal code, address, name, payment. Anything else (referral source, marketing opt-in, account creation) is optional or moved to post-purchase.

Dimension 2: Field design

How each field looks and behaves.

  • Labels above inputs beat placeholders. Placeholder labels disappear when typing.
  • Inline labels (floating labels) work for very compact forms.
  • Single column for almost every form. Eyes flow vertically.
  • Logical grouping with visible spacing. Don't put unrelated fields next to each other.
  • Right input type: email for emails, tel for phone, number for numbers, date for dates. Mobile keyboards adapt.
  • Autocomplete attributes: autocomplete="email", autocomplete="given-name", etc. Browsers and password managers fill them in.
  • Sensible defaults for fields where one applies (country pre-selected by IP, etc.). Don't default to anything that would mislead if wrong.

Dimension 3: Validation

Tell users what's wrong, when, and how to fix it.

  • Validate on blur, not on every keystroke. Inline errors that appear as someone types are jarring.
  • Re-validate on submit (catch fields the user skipped).
  • Specific messages: "Email must include @" beats "Invalid email."
  • Position errors next to the field they refer to.
  • Don't submit a form when there are errors. Highlight the first errored field. Scroll to it.
  • Validate server-side too. Client validation is UX. Server validation is correctness.

For format-flexible fields (phone numbers, postal codes), validate liberally. Reject only what's clearly wrong, not what's "non-standard." Many phone formats exist.

Dimension 4: Spam defense

Public forms attract spam. Plan for it from day one.

Layered defense:

  1. Honeypot field. A hidden field that humans don't fill in but bots do. If it's filled, reject silently. Free, low-friction, surprisingly effective for low-effort spam.
  2. Time-based detection. Reject submissions completed in under 2-3 seconds (bots) or after very long delays (suspicious sessions).
  3. Rate limiting. Reject if the same IP submits too many times.
  4. CAPTCHA as a last resort. Modern invisible CAPTCHAs (hCaptcha, reCAPTCHA v3, Turnstile) are low-friction. Old image CAPTCHAs are conversion-killers.
  5. Behavioral signals. Did the cursor move? Was there scroll? Modern services track this.
  6. Content filtering. Reject obvious spam content (links, foreign-language content if your audience is local, common spam words).
  7. Server-side review. A queue rather than direct delivery to inboxes for high-spam-target forms.

For most contact forms: honeypot + time check + Turnstile (or similar) is sufficient.

Dimension 5: Submission flow

What happens after submit.

  • Inline success message for short forms. Don't redirect just to confirm.
  • Confirmation page for high-value submissions (to provide next steps, set expectations).
  • Email confirmation for signups, purchases, RSVPs. Always.
  • Save data on errors so the user doesn't re-enter everything.
  • Optimistic UI (show success before the server confirms) for low-stakes forms; risky for high-stakes.

For multi-step forms:

  • Show progress (3 of 5)
  • Save state between steps (in case of refresh or navigation)
  • Allow back navigation without losing data
  • Validate per step, not just at the end

Workflow

Step 1: Audit current state

For each form on the site:

  • What's its purpose?
  • Number of fields, required vs optional
  • Current completion rate
  • Current spam rate
  • Validation rules
  • What happens after submit
  • Where the data goes downstream

Step 2: Define success per form

Different forms have different success metrics:

  • Lead form: qualified leads (defined by sales)
  • Newsletter: confirmed subscriptions (after double opt-in)
  • Contact: substantive replies (not just submissions)
  • Checkout: successful payments

Track the metric that matters, not just submissions.

Step 3: Cut fields ruthlessly

Apply the field strategy filter. For each field, answer:

  • Required to deliver value? Keep.
  • Nice to have? Move to optional or later.
  • Used for routing or qualification? Often can be inferred.

A 7-field form becomes a 3-field form. Conversion rises.

Step 4: Set up spam defense

Before launching a public form:

  • Add a honeypot field
  • Add time-based detection
  • Add rate limiting
  • Add a modern CAPTCHA if the form is high-traffic or high-spam

After launch, monitor. Tune layers based on what's actually getting through.

Step 5: Improve validation

Walk through each field:

  • Is validation specific?
  • Does it run at the right time (blur or submit, not on keystroke)?
  • Are error messages actionable?
  • Is server-side validation matching client-side?

Step 6: Verify accessibility

Critical baseline:

  • Every input has an associated label (visually visible or aria-label)
  • Errors are associated with inputs (aria-describedby, aria-invalid)
  • Focus order matches visual order
  • Color isn't the only way to indicate errors
  • Form is fully keyboard-navigable

See accessibility-audit for the full WCAG audit.

Step 7: Test downstream

Submit the form. Verify:

  • Data lands where it should
  • Required fields are populated correctly
  • Spam defenses are working (test with a script)
  • The user gets the confirmation they expect
  • Internal notification is timely

Forms break silently when downstream systems change. Test after any integration update.

Step 8: Monitor

  • Completion rate over time
  • Spam rate over time
  • Errors per submission (high errors = bad UX)
  • Drop-off field (where do people abandon?)

Failure patterns

Too many fields. Most B2B contact forms have 3x more fields than they need. Cut.

Validation that fires while typing. Annoying. Causes errors before the user has finished.

Generic error messages. "Invalid input." Where? Why? Be specific.

Required fields not marked. Users discover they're required only after submission fails. Mark required (or, for short forms, mark optional).

Autocomplete disabled. "For security." It's almost never a security improvement and always a UX cost. Leave autocomplete on.

Tab order is broken. Tab key skips fields or jumps backward. Set tabindex only when necessary; use natural DOM order.

Submit button below the fold. Especially on mobile. Users don't see it.

No save on error. User submits, has one error, returns to the form, all fields empty. Nightmare. Save the state.

Captcha as the only spam defense. Captchas are friction. Layered defense beats brute-force friction.

Captcha visible by default. Modern CAPTCHAs (Turnstile, reCAPTCHA v3) are invisible most of the time and only escalate when needed. Use those.

Newsletter signup that's actually a marketing list. Honor opt-in scope. If the user signed up for product updates, don't add them to the marketing newsletter.

Confirmation page that's a dead end. "Thanks for submitting" with no next step. What now? Provide an action (read related content, return to homepage, follow on social).

No double opt-in for marketing email. Bots and typos pollute the list. See email-deliverability for why this matters.

Email field accepting name@ as valid. Browser spec validation is loose. Validate against an actual format.

Custom date pickers worse than native. The native <input type="date"> is now good on most platforms. Don't reinvent unless you have a specific reason.

Forms that lose state on refresh. For long forms, save to localStorage and restore on load.


Output format

A form audit document includes:

  • Form inventory: every form on the site
  • Per-form review: purpose, fields, performance
  • Recommendations: field cuts, validation improvements, spam defense, design changes
  • Spam defense plan: layers per form
  • Accessibility status: WCAG compliance per form
  • Downstream integration map: where each form's data goes
  • Monitoring plan: what's tracked

Reference files

  • references/form-anatomy-checklist.md: A field-by-field, behavior-by-behavior checklist for auditing or designing a form, covering structure, accessibility, validation, and spam defense.

GitHub 仓库

rampstackco/claude-skills
路径: skills/form-strategy
0
agent-skillsai-agentsanthropicclaudeclaude-aiclaude-code

相关推荐技能

internationalization

其他

这是一个帮助开发者规划和实施多语言/多区域网站的Claude技能。它提供国际化(i18n)和本地化(l10n)的完整方案,包括URL结构选择、hreflang实施、翻译工作流和RTL语言设计等关键决策。当您需要扩展新语言市场、优化国际用户体验或修复停滞的国际化项目时,可以调用此技能获取跨技术栈的最佳实践指导。

查看技能

dependency-management

其他

该Skill帮助开发者管理第三方依赖,包括处理安全通告、评估新依赖、设置更新频率和解决升级阻塞问题。它能响应npm audit、Dependabot警报、构建失败或包废弃等触发场景。适用于维护依赖健康、降低供应链风险以及审计项目已安装的包。

查看技能

cost-optimization

其他

该Skill帮助开发者审计和优化云基础设施及SaaS工具成本,适用于月度账单审查、闲置资源清理、资源配置优化及供应商合同谈判等场景。它能识别未充分利用的资源、提供资源调整建议,并在财务支出上升或合同续约时自动触发。核心目标是实现成本节约的同时保持系统可靠性和开发效率。

查看技能

content-migration

其他

该Skill用于在不同平台、域名或URL结构间迁移内容,同时保持SEO价值、用户书签和集成不受影响。适用于CMS迁移、站点合并、URL重构等场景,能处理重定向映射和迁移规划。它提供平台无关的解决方案,确保内容迁移后不破坏现有权益与连接。

查看技能