To create and then add a component instance dynamically you should take following things into account:
- You should add the dependency of the desired component to the
rootDependencies
- Create the component using the document API method
createElement()
- Append the component to the Cubbles container (by default the
body
otherwise the element having thecubx-core-crc
attribute)
The code below presents this process for adding a new cubx-textarea
to an existing app:
<head> ... <script src="../../cubx.core.rte@2.2.3/webcomponents-lite/webcomponents-lite.js"></script> <script> // 1. You should add the dependency of the desired component to the rootDependencies window.cubx = { "CRCInit": { "rootDependencies": [ { "webpackageId": "com.incowia.basic-html-components@1.2", "artifactId": "cubx-textarea" } ] } } </script> <script src="../../cubx.core.rte@2.2.3/crc-loader/js/main.js" data-crcinit-loadcif="true"></script> </head> <body> ... <script> // 2. Create the component using the document API method createElement() var cubxTextArea = document.createElement('cubx-textarea'); // 3. Append the component to the Cubbles container document.body.appendChild(cubxTextArea); </script> </body>
You may also be interested in defining inits and connections for the component before appending it to the dom. Then, you should checkt the /wiki/spaces/RTE/pages/22156188 and the /wiki/spaces/RTE/pages/22156475.
Use document.createElement
Although you may want to append the component using the innerHTML
property of a container, we recommend you to use the document.createElement()
method, so that everything works properly.