This package is based on esri-loader.
npm i -S esri-module-loader
import { loadModules } from 'esri-module-loader'
A module value can be:
- a full module value is an object like
{ name: 'Map', path: 'esri/map' }
- or it can be a path string like
'your/path/to/module'
, which will be converted into{ name: 'module', path: 'your/path/to/module' }
- and it also can be a module name defined in shortcuts, like
'Map'
loadModules(moduleValue).then(Module => {})
To load multiple modules, you need an array of module values, like:
const modules = [
'esri/Color', // use last word as the module name
'Map', // by defined shortcut name
{ name: 'Graphic', path: 'esri/graphic' } // or you can specify your module name
]
loadModules(modules).then(({ Graphic, Map, Color }) => {
// loaded modules returned as an object mapping
// use your loaded modules here
})
needs extra dojo config:
loadModules(
[{ name: 'MyModule', path: 'my/Module'}],
{ dojoConfig: { packages: [ name: 'my', location: '/path/to/my' ] } }
).then(({ MyModule }) => {})
You can add your own shortcuts:
import { loadModules, shortcuts } from 'esri-module-loader'
shortcuts.add('Map', 'esri/map')
shortcuts.add({ name: 'Map', path: 'esri/map' })
shortcuts.add([{ name: 'Map', path: 'esri/map' }, { name: 'Color', path: 'esri/Color' }])
loadModules(['Map', 'Color']).then(({ Map, Color}) => {
// ...
})
Most of esri official modules have been already added into the shortcuts. You can check the module list
import { loadModules, config } from 'esri-module-loader'
config({
url: 'https://js.arcgis/com/4.8'
})
loadModules('Map').then(Map => {
// this is esri/Map from 4.8 api
})
loadModules('Map', {
url: url: 'https://js.arcgis/com/4.9' // this will override default loader options
}).then(Map => {
// this is esri/Map from 4.9 api
})