ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

vue-cli3 项目打包优化(解决首屏卡顿白屏,JS加载过多)

2021-03-30 23:57:54  阅读:263  来源: 互联网

标签:首屏 vue cli3 cdn element ui js config


开发环境 Vue-Cli3

1、vue-router懒加载功能

vue-cli3默认使用 Preload与Prefetch,

使用初衷是为了减少首页http请求过多,默认预加载了全部的js文件
vue.config.js 增加如下配置,取消prefetchpreload ,这样就是实现加载当前所需。

//vue.config.js
chainWebpack(config) {
    config.plugins.delete('preload') 
    config.plugins.delete('prefetch') 
  }
  1. Preload用来指定页面加载后很快会被用到的资源,所以在页面加载的过程中,我们希望在浏览器开始主体渲染之前尽早 preload。
  2. Prefetch用来告诉浏览器在页面加载完成后,利用空闲时间提前获取用户未来可能会访问的内容。
//router.js
component: () => import(/* webpackChunkName: "about",webpackPrefetch: true */ "../views/Home.vue"),

2、webpack CDN加速(externals外包扩展)

推荐CDN:bootcdn

//vue.config.js
const cdnMap = {
    css: [
        'https://cdn.bootcdn.net/ajax/libs/element-ui/2.10.2/theme-chalk/index.css'
    ],
    js: [
        'https://cdn.bootcdn.net/ajax/libs/vue/2.4.11/vue.min.js',
        'https://cdn.bootcdn.net/ajax/libs/vuex/2.9.1/vuex.min.js',
        'https://cdn.bootcdn.net/ajax/libs/vue-router/3.1.0/vue-router.min.js',
        'https://cdn.bootcdn.net/ajax/libs/axios/0.15.1/axios.min.js',
        'https://cdn.bootcdn.net/ajax/libs/element-ui/2.10.2/index.js',
        'https://cdn.bootcdn.net/ajax/libs/element-ui/2.10.2/locale/zh-CN.min.js',
    ]
}
// 需要扩展的资源
const externals = {
    vue: "Vue",
    vuex: "Vuex",
    "vue-router": "VueRouter",
    "element-ui":"element-ui",
    "axios":"axios",
}

const regDev = RegExp(/development/); // 开发环境

module.exports = {
  chainWebpack(config) {
        // 外部扩展
        config.externals((regDev.test(process.env.NODE_ENV))? {} : externals)
        config.plugin('html').tap(args => {
            args[0].cdn = (regDev.test(process.env.NODE_ENV))? {} : cdnMap
            return args
        })
    }
}
<head>
  <meta charset="utf-8">
  <meta http-equiv="X-UA-Compatible" content="IE=edge">
  <meta name="viewport" content="width=device-width,initial-scale=1.0">
  <title>cdn外部扩展</title>
  <% if (process.env.NODE_ENV !== 'development') { %>
    <% for(var css of htmlWebpackPlugin.options.cdn.css) { %>
      <link href="<%=css%>" rel="preload" as="style" />
      <link rel="stylesheet" href="<%=css%>" as="style" />
    <% } %>
    <% for(var js of htmlWebpackPlugin.options.cdn.js) { %>
      <link href="<%=js%>" rel="preload" as="script" />
      <script type="text/javascript" src="<%=js%>"></script>
    <% } %>
  <% } %>
</head>
<body>
  <div id="app"></div>
</body>

使用了externals之后依赖,里边所有的use都可以去掉了,因为外部差距都会先判断有没有vue实例,直接挂载上去,element-ui出现问题是因为本身与vue有强依赖关系,所以element-ui使用externals的基础上同时去掉main.js里的use

// 判断在开发模式下才是用引入  
const regDev = RegExp(/development/); // 为多个开发环境做的预留
if(regDev.test(process.env.NODE_ENV)){ //开发模式
  const ElementUI = require("element-ui"); // 不能使用import形式引入
  require("element-ui/lib/theme-chalk/index.css");
  const locale = require("element-ui/lib/locale/lang/zh-CN");
  Vue.use(ElementUI, {
    locale,
  });
}

标签:首屏,vue,cli3,cdn,element,ui,js,config
来源: https://blog.csdn.net/thyoyoyo/article/details/115339165

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有