Vue实现路由懒加载的多种方式总结
作者:mieRui
一、为什么需要路由懒加载
vue在项目打包/构建(一般是npm run build 具体看package.json文件)之后,会生成一个dist文件夹。在dist文件夹里面又有一个js/app.js文件,这里主要存放的是整个项目的业务逻辑代码。随着项目不断的开发迭代,业务逻辑越来越多,app.js文件也会越来越大。在线上就会容易出现进入首页时所需时间过长或者出现白屏的问题
这会是影响加载时间的重要因数。当构建的项目比较大的时候,懒加载可以分割代码块,提高页面的初始加载效率解决白屏问题。下面是几种常见vue路由懒加载的方法
1.ES6推荐方式imprort ()----推荐使用
// 官网可知:下面没有指定webpackChunkName,每个组件打包成一个js文件。 const Foo = () => import('../components/Foo') const Aoo = () => import('../components/Aoo') // 下面2行代码,指定了相同的webpackChunkName,会合并打包成一个js文件。 const Foo = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../components/Foo') const Aoo = () => import(/* webpackChunkName: 'ImportFuncDemo' */ '../components/Aoo')
2 webpack提供的require.ensure()实现懒加载
1:这种情况下,多个路由指定相同的chunkName,会合并打包成一个js文件。
2:require.ensure可实现按需加载资源,包括js,css等。他会给里面require的文件单独打包,不会和主文件 打包在一起。
3:第一个参数是数组,表明第二个参数里需要依赖的模块,这些会提前加载。
4:第二个是回调函数,在这个回调函数里面require的文件会被单独打包成一个chunk,不会和主文件打包在一 起,这样就生成了两个chunk,第一次加载时只加载主文件。
5:第三个参数是错误回调。
6:第四个参数是单独打包的chunk的文件名
import Vue from 'vue'; import Router from 'vue-router'; Vue.use('Router') export default new Router({ routes:[{ {path:'./', name:'HelloWorld', component: r => require.ensure([], () => r(require('@/components/home')), 'demo') } }] })
3.使用vue异步组件resolve
这一种方法比较常见。它主要是使用了resolve的异步机制,用require代替了import,实现按需加载,下面是代码示例
//const 组件名 = resolve => require([‘组件路径'],resolve) //(这种情况下一个组件生成一个js文件) const home = resolve => require(['../view/home'],resolve)
4.import和require的比较(了解)
import 是解构过程并且是编译时执行
require 是赋值过程并且是运行时才执行,也就是异步加载
require的性能相对于import稍低,因为require是在运行时才引入模块并且还赋值给某个变量
命令 | 规范 | 调用 | 本质 | 特点 |
require | CommonJS规范 | 运行时调用 | 赋值过程 | 非语言层面的标准。 社区方案,提供了服务器/浏览器的模块加载方案。只能在运行时确定模块的依赖关系及输入/输出的变量,无法进行静态优化。 |
import | es6+的语法标准 | 编译时调用 | 解构过程 | 语言规格层面支持模块功能。支持编译时静态分析,便于JS引入宏和类型检验。动态绑定 |
关于规范
import是es6的一个语法标准,如果要兼容浏览器的话必须转化成es5的语法。
到此这篇关于Vue实现路由懒加载的多种方式总结的文章就介绍到这了,更多相关Vue路由懒加载内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!