vue 组件按需引用,vue-router懒加载,vue打包优化,加载动画

当打包构建应用时,Javascript 包会变得很是大,影响页面加载。若是咱们能把不一样路由对应的组件分割成不一样的代码块,而后当路由被访问的时候才加载对应组件,这样就更加高效了。html

结合 Vue 的 异步组件 和 Webpack 的 code splitting feature, 轻松实现路由组件的懒加载。vue

咱们要作的就是把路由对应的组件定义成异步组件webpack

const Foo = resolve => {
  // require.ensure 是 Webpack 的特殊语法,用来设置 code-split point
  // (代码分块)
  require.ensure(['./Foo.vue'], () => {
    resolve(require('./Foo.vue'))
  })
}

这里还有另外一种代码分块的语法,使用 AMD 风格的 require,因而就更简单了:git

const Foo = resolve => require(['./Foo.vue'], resolve) 

不须要改变任何路由配置,跟以前同样使用 Foogithub

const router = new VueRouter({
  routes: [
    { path: '/foo', component: Foo }
  ]
}) 

把组件按组分块

有时候咱们想把某个路由下的全部组件都打包在同个异步 chunk 中。只须要 给 chunk 命名,提供 require.ensure 第三个参数做为 chunk 的名称:web

const Foo = r => require.ensure([], () => r(require('./Foo.vue')), 'group-foo')
const Bar = r => require.ensure([], () => r(require('./Bar.vue')), 'group-foo')
const Baz = r => require.ensure([], () => r(require('./Baz.vue')), 'group-foo')

Webpack 将相同 chunk 下的全部异步模块打包到一个异步块里面 —— 这也意味着咱们无须明确列出 require.ensure 的依赖(传空数组就行)。npm

若是你想在组件加载的时候能够有loading提示也一样的很简单数组

这里以mint-ui为例异步

import { Indicator } from 'mint-ui';
//前提是npm i mint-ui -S

而后你就只须要稍微加一点代码ide

const Foo = resolve => {
Indicator.open();
  require.ensure(['./Foo.vue'], () => {
    resolve(require('./Foo.vue'))
    Indicator.close()
  })
}
//这样就能够实现组件在异步加载的时候显示loading

效果以下

相关文章
相关标签/搜索