Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/degjs/moduleloader
Asynchronously load JavaScript modules via an HTML attribute.
https://github.com/degjs/moduleloader
Last synced: about 1 month ago
JSON representation
Asynchronously load JavaScript modules via an HTML attribute.
- Host: GitHub
- URL: https://github.com/degjs/moduleloader
- Owner: DEGJS
- Created: 2015-08-21T20:37:33.000Z (over 9 years ago)
- Default Branch: main
- Last Pushed: 2023-01-04T12:59:21.000Z (almost 2 years ago)
- Last Synced: 2024-04-26T21:02:58.370Z (8 months ago)
- Language: JavaScript
- Homepage:
- Size: 866 KB
- Stars: 1
- Watchers: 12
- Forks: 0
- Open Issues: 10
-
Metadata Files:
- Readme: README.md
Awesome Lists containing this project
README
# moduleLoader
![Run Tests](https://github.com/DEGJS/moduleLoader/workflows/Run%20Tests/badge.svg)Whenever possible, it's best to bundle modules during development. However, in certain situations (such as a restrictive CMS, or when loading JavaScript after a specific user interaction), it may be necessary to load a module asynchronously at runtime.
The moduleLoader module does exactly that, either on page load or on demand via an HTML attribute.
## Install
moduleLoader is an ES6 module. Consequently, you may need a transpiler ([Babel](https://babeljs.io) is a nice one) to compile moduleLoader into compatible Javascript for your runtime environment.If you're using NPM, you can install moduleLoader with the following command:
```
$ npm install @degjs/module-loader
```## Usage
Regardless of whether you load modules on page load or on demand, you must set the `data-module` attribute on your HTML elements:
```html
Component 1
Component 2
```### Option A: Load modules on page load
```js
import moduleLoader from "@degjs/module-loader";moduleLoader();
```### Option B: Load modules on demand
moduleLoader uses the [MutationObserver](https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver) API to watch for elements with `data-module` attributes that are added to the DOM by JavaScript after the page is loaded.
```js
import moduleLoader from "@degjs/module-loader";moduleLoader();
document.body.insertAdjacentHTML('beforeend', `
Component 3
`);
```Upon each successful load, an object is passed to the loaded module containing the following values:
* **containerElement:** The element from which the module was called.
## Options
#### options.moduleDataAttr
Type: `String`
The name of the data attribute that defines the module to be loaded.
Default: `data-module`#### options.elToObserve
Type: `Element`
The DOM element to observe for dynamically added elements.
Default: `document.body`#### options.enableObservation
Type: `Boolean`
In some cases, you may know that no elements with modules will be added to the page after page load. Setting to `false` disables the potentially expensive mutation observer.
Default: `true`#### options.loadingMethod
Type: `String`
By default, moduleLoader will attempt to load native JavaScript modules using the `import()` method, but will automatically fall back to SystemJS's `System.import()` method in unsupported browsers. This behavior can be overridden with this setting.
Options: `auto, system, esm`
Default: `auto`#### options.basePath
Type: `String`
The base path of the JS module. This can be overridden at the element level by adding a `data-basepath` attribute to the element.
Default: `/js/`#### options.filenameSuffix
Type: `String`
The suffix of the JS bundle being loaded in browsers that support modules. This can be overridden at the element level by adding a `data-suffix` attribute to the element.
Default: `-bundle.js`#### options.filenameNoModuleSuffix
Type: `String`
The suffix of the JS bundle being loaded in browsers that don't support modules. This can be overridden at the element level by adding a `data-no-module-suffix` attribute to the element.
Default: `-bundle-nomodule.js`## Browser Support
moduleLoader depends on the following browser APIs:
+ MutationObserver: [Documentation](https://developer.mozilla.org/en-US/docs/Web/API/MutationObserver) | [Polyfill](https://github.com/megawac/MutationObserver.js) (Note: moduleLoader 4.0.2+ will work in IE10 without a polyfill, but dynamic module loading after the DOM is loaded will not. For IE10, either polyfill or use [moduleLoader 3.0.1](https://github.com/DEGJS/moduleLoader/tree/3.0.1))To support legacy browsers, you'll need to include polyfills for the above APIs.