vue-router和webpack懒加载,页面性能优化篇

发布时间:2019-05-28 发布网站:脚本宝典
脚本宝典收集整理的这篇文章主要介绍了vue-router和webpack懒加载,页面性能优化篇脚本宝典觉得挺不错的,现在分享给大家,也给大家做个参考。

在vue单页应用中,当项目不断完善丰富时,即使使用webpack打包,文件依然是非常大的,影响页面的加载。如果我们能把不同路由对应的组件分割成不同的代码块,当路由被访问时才加载对应的组件(也就是按需加载),这样就更加高效了。——引自vue-router官方文档

如何实现??

vue异步组件

vue-router配置路由,使用vue的异步组件技,可以实现懒加载,代码如下:// 每个组件都会生成一个js文件

import Vue From 'vue'
import Router from 'vue-router'
import LOGin from '../view/List.vue';

Vue.use(Router);

export default new Router({
routes: [
  {
    path: '/home/list',
    name: 'list',
    components: resolve => require(['../view/List.vue'], resolve)
  }
],

动态import(webpack > 2.4)

vue、webpack官方推荐

情况一:每个组件都会打包生成一个js文件


const List = () => import('../view/List.vue')

// 在路由配置中什么都不需要改变,像往常一样使用组件:
export default new Router({
routes: [
  {
    path: '/home/list',
    name: 'login',
    components: Login
  },
  {
    path: '/home/user',
    name: 'user',
    components: User
  }
],

情况二:所有组件合并打包在一个异步块chunk中


const List = () => import(/* webpackChunkName: "home" */ './List.vue')
const User = () => import(/* webpackChunkName: "home" */ './User.vue')

// 在路由配置中什么都不需要改变,像往常一样使用组件:
export default new Router({
routes: [
  {
    path: '/home/list',
    name: 'list',
    components: List
  },
  {
    path: '/home/user',
    name: 'user',
    components: User
  }
],

// 在webpack.base.config.js中配置 ChunkFileName:
output: {
path: config.build.assetsRoot,
filename: '[name].js',
chunkFilename: '[name].js',
publicPath: process.env.NODE_ENV === 'production'
  ? config.build.assetsPublicPath
  : config.dev.assetsPublicPath
},

另一种写法,更简洁:同样需要在webpack.base.config.js中配置 ChunkFileName:


{
  path: '/home/list',
  name: 'list',
  component: () => import(/* webpackChunkName:"list"*/ '../view/List.vue')
},
{
  path: '/home/user',
  name: 'user',
  component: () => import(/* webpackChunkName:"user"*/ '../view/User.vue')
},

webpack提供的require.ensure()

语法如下:摘自官网

require.ensure(dePEndencies: String[], callback: function(require), chunkName: String

多个路由指定相同的chunkName,在这里chunkName为home,会合并打包成一个js文件。

{
 path: '/home/list',
 name: 'list',
 // component:list
 component: r => require.ensure([], () => r(require('../view/Lst.vue')), 'home')
},
{
 path: '/home/user',
 name: 'user',
 // component:user
 component: r => require.ensure([], () => r(require('../view/User.vue')), 'home')
}

// 在webpack.base.config.js中配置 ChunkFileName 和 publicPath:
output: {
path: config.build.assetsRoot,
filename: '[name].js',
chunkFilename: '[name].js',
publicPath: './',
publicPath: process.env.NODE_ENV === 'production'
  ? config.build.assetsPublicPath
  : config.dev.assetsPublicPath
},

在实践过程中应该会遇到各种问题,到时候再继续补充,前端新手,多多指教!

脚本宝典总结

以上是脚本宝典为你收集整理的vue-router和webpack懒加载,页面性能优化篇全部内容,希望文章能够帮你解决vue-router和webpack懒加载,页面性能优化篇所遇到的问题。

如果觉得脚本宝典网站内容还不错,欢迎将脚本宝典推荐好友。

本图文内容来源于网友网络收集整理提供,作为学习参考使用,版权属于原作者。
如您有任何意见或建议可联系处理。小编QQ:384754419,请注明来意。