前言
Vue我的项目开发结束后,对我的项目进行打包公布之前,必不可少的操作就是我的项目优化,这也是程序猿的加分项。追随本文的脚步来看看如何对我的项目进行优化吧~
一、路由懒加载
- 为什么须要路由懒加载
当刚运行我的项目的时候,发现刚进入页面,就将所有的js文件和css文件加载了进来,这一过程非常的耗费工夫。 如果关上哪个页面就对应的加载响应页面的js文件和css文件,那么页面加载速度会大大晋升。 - 如何实现路由懒加载
vue官网文档:路由懒加载 代码如下(示例):
{ path: '/login', component: () => import('@/views/login/index'), hidden: true },复制代码
- 路由懒加载中的魔法正文
通过在正文中指定webpackChunkName,能够自定义这个文件的名字。 代码如下(示例):
components = () => import(/* webpackChunkName:"login"*/ "../component/Login.vue")复制代码
二、剖析包大小
- 需要
想要晓得打包生成的文件中,每个文件所占的空间大小。以便于咱们剖析,对代码进行优化解决。 - 如何生成打包剖析文件
终端中运行 npm run preview -- --report, 这个命令会从咱们的入口main.js进行依赖剖析,剖析出各个包的大小。最终会在生成的dist文件夹下生成一个report.html的文件,关上后就能够看到咱们在我的项目应用文件占据的空间大小啦~
(效果图如下:)
三、webpack配置排除打包
- 需要
将一些不罕用的包,排除在生成的打包文件以外。 例如:上图所示的xsxl.js 、 element.js,能够将其排除在打包生成的文件以外 - 排除打包
找到 vue.config.js, 增加 externals 项,具体如下:
代码如下(示例):
configureWebpack: { // 配置单页应用程序的页面的题目 name: name, externals: { /** * externals 对象属性解析。 * 根本格局: * '包名' : '在我的项目中引入的名字' * */ 'vue': 'Vue', 'element-ui': 'ElementUI', 'xlsx': 'XLSX' }, resolve: { alias: { '@': resolve('src') } }}复制代码
四、 援用网络资源
- 需要
咱们进行了上一步操作当前,打包生成后的包小了很多。然而呢,没有这些依赖包的话,我的项目上线是没有方法运行的。那么就须要援用网络中的资源,来反对咱们代码的运行。 - CDN
CDN全称叫做“Content Delivery Network”,中文叫内容散发网络。咱们用它来进步访问速度
把一些动态资源:css, .js,图片,视频放在第三方的CDN服务器上,能够减速访问速度。
益处:
缩小利用打包进去的包体积
放慢动态资源的拜访
利用浏览器缓存,不会变动的文件长期缓存
- 实现步骤
留神:在开发环境时,文件资源还是能够从本地node_modules中取出,而只有我的项目上线了,才须要去应用内部资源。此时咱们能够应用环境变量来进行辨别。具体如下:
代码如下(示例):
在vue.config.js文件中:
let externals = {}let cdn = { css: [], js: [] }const isProduction = process.env.NODE_ENV === 'production' // 判断是否是生产环境if (isProduction) { externals = { /** * externals 对象属性解析: * '包名' : '在我的项目中引入的名字' */ 'vue': 'Vue', 'element-ui': 'ELEMENT', 'xlsx': 'XLSX' } cdn = { css: [ 'https://unpkg.com/element-ui/lib/theme-chalk/index.css' // element-ui css 样式表 ], js: [ // vue must at first! 'https://unpkg.com/vue@2.6.12/dist/vue.js', // vuejs 'https://unpkg.com/element-ui/lib/index.js', // element-ui js 'https://cdn.jsdelivr.net/npm/xlsx@0.16.6/dist/xlsx.full.min.js', // xlsx ] }}复制代码
webpack配置externals配置项
configureWebpack: { // 配置单页应用程序的页面的题目 name: name, externals: externals, resolve: { alias: { '@': resolve('src') } }}复制代码
通过 html-webpack-plugin注入到 index.html之中: 在vue.config.js文件中配置:
chainWebpack(config) { config.plugin('preload').tap(() => [ { rel: 'preload', fileBlacklist: [/\.map$/, /hot-update\.js$/, /runtime\..*\.js$/], include: 'initial' } ]) // 注入cdn变量 (打包时会执行) config.plugin('html').tap(args => { args[0].cdn = cdn // 配置cdn给插件 return args }) // 省略其余...}复制代码
找到 public/index.html 通过配置CDN Config 顺次注入 css 和 js。 批改head的内容如下:
<head> <meta charset="utf-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge,chrome=1"> <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1, user-scalable=no"> <link rel="icon" href="<%= BASE_URL %>favicon.ico"> <title><%= webpackConfig.name %></title> <!-- 引入款式 --> <% for(var css of htmlWebpackPlugin.options.cdn.css) { %> <link rel="stylesheet" href="<%=css%>"> <% } %> <!-- 引入JS --> <% for(var js of htmlWebpackPlugin.options.cdn.js) { %> <script src="<%=js%>"></script> <% } %> </head>复制代码
五、 打包去除console.log
- 需要
在我的项目打包上线后,去除掉代码中所有的console.log - 代码演示
在vue.config.js文件中配置: 代码如下(示例):
chainWebpack(config) { config.optimization.minimizer('terser').tap((args) => { args[0].terserOptions.compress.drop_console = true return args })}
最初
如果你感觉此文对你有一丁点帮忙,点个赞。或者能够退出我的开发交换群:1025263163互相学习,咱们会有业余的技术答疑解惑
如果你感觉这篇文章对你有点用的话,麻烦请给咱们的开源我的项目点点star: https://gitee.com/ZhongBangKe...不胜感激 !