Learn-skills.dev webflow-code-components
Build, define, and import React code components into Webflow via DevLink. Use when creating Webflow code components, configuring declareComponent definitions, working with prop types, styling within Shadow DOM, bundling with Webpack, or troubleshooting DevLink imports.
install
source · Clone the upstream repo
git clone https://github.com/NeverSight/learn-skills.dev
Claude Code · Install into ~/.claude/skills/
T=$(mktemp -d) && git clone --depth=1 https://github.com/NeverSight/learn-skills.dev "$T" && mkdir -p ~/.claude/skills && cp -r "$T/data/skills-md/224-industries/webflow-skills/webflow-code-components" ~/.claude/skills/neversight-learn-skills-dev-webflow-code-components && rm -rf "$T"
manifest:
data/skills-md/224-industries/webflow-skills/webflow-code-components/SKILL.mdsource content
Webflow Code Components
Build, define, and import React code components into Webflow using DevLink. Code components let you develop advanced, interactive React components in your codebase and deploy them to Webflow as shared libraries for visual composition on the canvas.
Quick Start
Prerequisite: Webflow Workspace on Freelancer, Core, Growth, Agency, or Enterprise plan (or a site on CMS, Business, or Enterprise). Node.js 20+ and npm 10+.
- Set up your project — Install the CLI and dependencies
- Create a React component — Build your standard React component
- Define the code component — Create a
file with.webflow.tsxdeclareComponent - Import to Webflow — Run
npx webflow library share - Use on canvas — Install the library on a site, then drag and drop components
See
references/quick-start.md for a full end-to-end tutorial.
Key Concepts
- Shadow DOM isolation — Styles and DOM are sandboxed per component
- Separate React roots — No shared React Context or state between components. Use URL params, browser storage, Nano Stores, or custom events
- SSR by default — Server-rendered HTML is hydrated on the client. Disable with
for browser-only componentsssr: false
— Defines how your React component appears in Webflow. SeedeclareComponent
for the full APIreferences/hooks.md- Prop types — 11 types available (
,Text
,Rich Text
,Text Node
,Link
,Image
,Number
,Boolean
,Variant
,Visibility
,Slot
)ID - Bundling — Webpack bundles your library (50MB max)
Important Notes
- File names are unique identifiers. Renaming a
file creates a new component and removes the old one — existing instances on sites will break..webflow.tsx - React Server Components are not supported. Use standard React components only.
- Components can fetch data client-side, but APIs must support CORS and you must never embed API keys in component code.
Reference Documentation
Each reference file includes YAML frontmatter with
name, description, and tags for searchability. Use the search script in scripts/search_references.py to find relevant references.
Getting Started
- references/introduction.md: Overview of DevLink and code components
- references/quick-start.md: End-to-end tutorial from setup to canvas
- references/installation.md: CLI installation,
config, authenticationwebflow.json
Building Components
- references/define-code-component.md:
, props, decorators, optionsdeclareComponent - references/hooks.md:
anddeclareComponent
hook referenceuseWebflowContext - references/component-architecture.md: Shadow DOM, SSR, state patterns, data fetching
- references/styling-components.md: CSS in Shadow DOM, site variables, tag selectors
- references/frameworks-and-libraries.md: Tailwind, styled-components, Emotion, Material UI, Shadcn/UI, Sass, Less
Prop Types
- references/prop-types.md: All prop types with usage, return values, and examples
- references/prop-types/text.md: Text — single-line text input
- references/prop-types/rich-text.md: Rich Text — formatted HTML content
- references/prop-types/text-node.md: Text Node — on-canvas editable text
- references/prop-types/link.md: Link — URL with target and preload
- references/prop-types/image.md: Image — asset library image selection
- references/prop-types/number.md: Number — numeric input with range controls
- references/prop-types/boolean.md: Boolean — true/false toggle
- references/prop-types/variant.md: Variant — predefined option dropdown
- references/prop-types/visibility.md: Visibility — show/hide toggle
- references/prop-types/slot.md: Slot — child component insertion
- references/prop-types/id.md: ID — HTML element identifier
Bundling & CLI
- references/cli.md: Webflow CLI commands, flags, CI/CD usage, troubleshooting
- references/bundling-and-import.md: Webpack bundling, CLI import, CI/CD, debugging
Help
- references/faq.md: Frequently asked questions — setup, styling, imports, troubleshooting, performance
Searching References
# List all references with metadata python scripts/search_references.py --list # Search by tag (exact match) python scripts/search_references.py --tag <tag> # Search by keyword (across name, description, tags, and content) python scripts/search_references.py --search <query> # Search only prop type references python scripts/search_references.py --prop-types python scripts/search_references.py --prop-types --tag <tag> python scripts/search_references.py --prop-types --search <query>
Scripts
: Search reference files by tag, keyword, or list all with metadatascripts/search_references.py