前言
Vue我的项目开发结束后,对我的项目进行打包公布之前,必不可少的操作就是我的项目优化,这也是程序猿的加分项。追随本文的脚步来看看如何对我的项目进行优化吧~

一、路由懒加载

  1. 为什么须要路由懒加载
    当刚运行我的项目的时候,发现刚进入页面,就将所有的js文件和css文件加载了进来,这一过程非常的耗费工夫。 如果关上哪个页面就对应的加载响应页面的js文件和css文件,那么页面加载速度会大大晋升。
  2. 如何实现路由懒加载
    vue官网文档:路由懒加载 代码如下(示例):
{    path: '/login',    component: () => import('@/views/login/index'),    hidden: true  },复制代码
  1. 路由懒加载中的魔法正文
    通过在正文中指定webpackChunkName,能够自定义这个文件的名字。 代码如下(示例):
components = () => import(/* webpackChunkName:"login"*/ "../component/Login.vue")复制代码

二、剖析包大小

  1. 需要
    想要晓得打包生成的文件中,每个文件所占的空间大小。以便于咱们剖析,对代码进行优化解决。
  2. 如何生成打包剖析文件
    终端中运行 npm run preview -- --report, 这个命令会从咱们的入口main.js进行依赖剖析,剖析出各个包的大小。最终会在生成的dist文件夹下生成一个report.html的文件,关上后就能够看到咱们在我的项目应用文件占据的空间大小啦~

(效果图如下:)

三、webpack配置排除打包

  1. 需要
    将一些不罕用的包,排除在生成的打包文件以外。 例如:上图所示的xsxl.js 、 element.js,能够将其排除在打包生成的文件以外
  2. 排除打包
    找到 vue.config.js, 增加 externals 项,具体如下:

代码如下(示例):

configureWebpack: {  // 配置单页应用程序的页面的题目  name: name,  externals: {     /**      * externals 对象属性解析。      *  根本格局:      *     '包名' : '在我的项目中引入的名字'      *      */    'vue': 'Vue',    'element-ui': 'ElementUI',    'xlsx': 'XLSX'  },  resolve: {    alias: {      '@': resolve('src')    }  }}复制代码

四、 援用网络资源

  1. 需要
    咱们进行了上一步操作当前,打包生成后的包小了很多。然而呢,没有这些依赖包的话,我的项目上线是没有方法运行的。那么就须要援用网络中的资源,来反对咱们代码的运行。
  2. CDN
    CDN全称叫做“Content Delivery Network”,中文叫内容散发网络。咱们用它来进步访问速度
    把一些动态资源:css, .js,图片,视频放在第三方的CDN服务器上,能够减速访问速度。
    益处:

缩小利用打包进去的包体积
放慢动态资源的拜访
利用浏览器缓存,不会变动的文件长期缓存

  1. 实现步骤
    留神:在开发环境时,文件资源还是能够从本地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

  1. 需要
    在我的项目打包上线后,去除掉代码中所有的console.log
  2. 代码演示
    在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...不胜感激 !