#html-scoped-component-importer
This is a simple tool to let you create and dynamically import scoped components. All you need is a html element with the data-component attribute and it will be imported and initialized.
yarn
yarn add html-scoped-component-importer
npm
npm install --save html-scoped-component-importer
module.exports = {
...
resolve: {
alias: {
COMPONENTS: path.resolve(__dirname, '{your components folder}'),
}
}
...
}
import { ComponentDispatcher } from 'html-scoped-component-importer';
const compDispatcher = new ComponentDispatcher();
compDispatcher.createAsyncComponents();
export default class ExampleComponent {
constructor(element) {
super(element);
element.innerHTML = element.dataset.component;
}
}
<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>Title</title>
<script async="async" defer="defer" src="main.js"></script>
</head>
<body>
<div data-component="ExampleComponent"></div>
</body>