补充上一篇 实现基于最新chrome的动态按需加载组件
2018-01-05 本文已影响127人
飞凡的陀螺
先看 这里
有一个提案,建议引入import()
函数,完成动态加载。
import(specifier)
上面代码中,import
函数的参数specifier
,指定所要加载的模块的位置。import
命令能够接受什么参数,import()
函数就能接受什么参数,两者区别主要是后者为动态加载。
import()
返回一个 Promise 对象。下面是一个例子。
const main = document.querySelector('main');
import(`./section-modules/${someVariable}.js`)
.then(module => {
module.loadPageInto(main);
})
.catch(err => {
main.textContent = err.message;
});
import()
函数可以用在任何地方,不仅仅是模块,非模块的脚本也可以使用。它是运行时执行,也就是说,什么时候运行到这一句,也会加载指定的模块。另外,import()
函数与所加载的模块没有静态连接关系,这点也是与import
语句不相同。
import()
类似于 Node 的require
方法,区别主要是前者是异步加载,后者是同步加载。
syntax-dynamic-import
这种方式chrome63后已经原生支持了,但是如果是不支持浏览器就需要babel了。
看这里 https://babeljs.io/docs/plugins/syntax-dynamic-import/
运用
- vue的router.js中
import Vue from 'vue'
import Router from 'vue-router'
Vue.use(Router)
function load(component) {
// '@' is aliased to src/components
return () => import(`@/pages/${component}/index.vue`)
}
export default new Router({
routes: [
{
path: '/',
name: 'HelloWorld',
component: load('HelloPage')
},
{
path: '/tree',
name: 'TreePage',
component: load('TreePage')
}
]
})
- vue加载多components
// http://www.css88.com/doc/lodash/#_kebabcasestring
// UploadFile => upload-file
import { kebabCase } from 'lodash'
const load = (component) => {
return () => import(`../components/${component}.vue`)
}
const commonComponents = [
'BaseFormDialog',
'Datepicker',
'HeaderContent',
'UploadFile',
'FullScreenButton',
'RouterTreeview',
'RouterLinkBack',
'ModalDialog',
'vSelect'
]
commonComponents.forEach(component => {
Vue.component(kebabCase(component), load(component));
})