A script loader for modular components in es6 (build process coming soon). This is built so that each components being responsible for what 3rd party dependencies they need.
- if script has not been loaded, it will load the script, and return a promise
onLoadHandler
andonErrorHandler
will execute on script load and on script error- script promise will be resolved when the script is loaded, rejects if it errors
- if a script has already been requested to load throught dynamic script loader, it will return the existing promise
- all script proimses are added to
window.dynamicScriptLoader
global object
npm i -S dynamic-script-loader
simple
const scriptLoader = require('dynamic-script-loader')
scriptLoader({
src: ''//path/to/someExternalJS.js'
},
onLoadHandler, // optional
onErrorHandler // optional
)
.then(resolverFunction)
.catch(catchFunction)
creating a vue wrapper for 3rd party libraries
heres a couple of ways you can use the script loader
import scriptLoader from 'dynamic-script-loader'
Vue.use({
install: function (Vue, options) {
Vue.prototype.$scriptLoader = scriptLoader
})
// inside a Vue component
data () {
return {
message: '',
error: ''
}
},
mounted () {
// the loader will not load libraries if they have already been loaded
this.$scriptLoader({
src: '//some-cdn/src/js/library.js',
async: true
}, () => {
// one time setup
some3rdPartyLib.credentials('123')
some3rdPartyLib.partyTime = true
some3rdPartyLib.breakRandomly = Math.random() % 2 === 1
})
.then(() => {
// something to run everytime this component is mounted
this.message = some3rdPartyLib.getMessage()
})
.catch(() => {
// script failed to load
this.error = 'oops'
})
}
script loading uses URL's as unique keys so if urls change by for example, query string, then the script will try to load it again. example:
- urlA =
//www.example.com/script.js
- urlB =
https://www.example.com/script.js
- urlC =
https://www.example.com/script.js?hi
the script loader will treat these as separate javascript files
- use typescript!
git clone [email protected]:john-ko/dynamic-script-loader.git
cd dynamic-script-loader
npm install
add changes
npm test