Component Overview
Webflow Components are customizable blocks created from Elements. They serve as the backbone for structuring visual hierarchies on a Webflow site, ensuring that designs are modular, reusable, and consistent.
Let’s review some key concepts of Components, and how they’re implemented in Webflow.
Definitions
Component Definition
Also known as the component object, the component definition is the blueprint for a component. It establishes the foundational structure of the elements within the component, as well as properties that can be further defined in a component instance. Any modifications made to the component definition will propagate and automatically update all associated component instances. This ensures consistency across instances while allowing for centralized changes.
Use components to manage recurring layouts and content more efficiently across your site.
Component Instance
A component instance is a concrete instantiation of the component definition. While it retains the core design and structure of the definition, each instance can be customized through unique properties. This allows designers and users to assign custom values to a component instance’s properties, tailoring its appearance and behavior, without modifying the underlying component definition..
Component Operations
With Component concepts explained, here is a quick overview of the capabilities offered by the Components API:
🛠️ Create a Component Definition
To create a component definition you’ll need a root element - or top-level element - that has child elements within its element hierarchy. With the root element identified, you can use webflow.registerComponent(rootElement)
to register the component definition. In the above card component example, the root element would be the container DIV element, which has the img
, div
, and button
child elements.
✏️ Edit a Component Definition
- Get the component
- Get the root element of the component
- Insert / remove child elements from the root element.
✏️ Adding a Component Instance to a Page
Use webflow.createInstance(componentDefinition)
to add a component instance to the page. Component instances can be nested as part of element hierarchies, including under other component instances.
Component Properties
Pre-defined attributes within a Component Definition that can be assigned a specific value in the Component Instance. They allow designers or users to modify specific aspects of an Instance - text, images, links, and more - without affecting its foundational design.
Component Properties
Currently our APIs do not yet support the creation and management of Component Properties.
We understand the importance of this feature for our users, and we’re excited to share that it’s on our development roadmap. We’re committed to enhancing our API capabilities and will provide updates as we make progress. Thank you for your patience and understanding!