乐趣区

关于vue.js:Vue项目优化打包前端加分项

前言
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… 不胜感激!

退出移动版