With Wix custom elements, you can add elements that do not come "out of the box" with Wix. First, create and code the element and its behavior in a JavaScript file. Then add the custom element to your site in the editor.
This article assumes that you know a bit about designing elements with CSS properties in Javascript and working with web components. This article provides an overview of the code to get you started, providing links and pointers along the way.
In this article, we'll use this company logo as our custom element:
Our goal is to display the custom element on our site, without adding any special behaviors.
Use any IDE to create custom elements in a static Javascript file using the standard ECMAScript 2015 class syntax.
Note: This article provides basic instructions for creating custom elements. For full instructions and examples, see the MDN documentation.
To start, let's code the implementation of a basic, custom element without any special behaviors. For now, this element will be a company logo for display purposes only.
(Our logo comprises two separate images, because we have plans to make the different parts of the logo behave differently. But let's save that for later.)
We assume the logo images have already been uploaded to the Wix Media Manager.
Let's add a function that accepts each part of the logo and adds it to the DOM. This function sets the size and position of each logo image.
Now we define the actual custom element class.
myLogoDisplay
class is the class of the custom element, which we'll use when registering the custom element.constructor()
and super()
functions to create an instance of the element.connectedCallback()
is a lifecycle callback function that is triggered automatically when the element is connected. When the custom element is able to start rendering on the site, the two parts of our logo image can be displayed, with the help of the createImg()
function.Our last step is to register the custom element class with the customElements.define(name, class)
method.
Once registered, new custom elements can be used in your site.
my-logo-display
, maps to the tag name, which we'll soon define in the Wix Editor.myLogoDisplay
, is the class name of the custom element.Here is the code for our custom element in a single snippet for your convenience:
The next step is to add the custom element to our page.
In the element's Settings:
customElements.define()
function in the previous step. So in this case our tag name is my-logo-display
.We have now accomplished our goal, displaying the custom element on our site, without adding any special behaviors.
Learn More Try this example to learn how to change the logo's behavior when visitors perform actions on our site, such as making the logo spin, resize, and shake.