vue-cli3 项目打包优化(解决首屏卡顿白屏,JS加载过多)
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了vue-cli3 项目打包优化(解决首屏卡顿白屏,JS加载过多),小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2784字,纯文字阅读大概需要4分钟。
内容图文
![vue-cli3 项目打包优化(解决首屏卡顿白屏,JS加载过多)](/upload/InfoBanner/zyjiaocheng/1025/b93e2bfa25e149ae90917605ec45fb52.jpg)
开发环境 Vue-Cli3
1、vue-router懒加载功能
vue-cli3默认使用 Preload与Prefetch,
使用初衷是为了减少首页http请求过多,默认预加载了全部的js文件
vue.config.js
增加如下配置,取消prefetch
和preload
,这样就是实现加载当前所需。
//vue.config.js
chainWebpack(config) {
config.plugins.delete('preload')
config.plugins.delete('prefetch')
}
Preload
用来指定页面加载后很快会被用到的资源,所以在页面加载的过程中,我们希望在浏览器开始主体渲染之前尽早 preload。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 项目打包优化(解决首屏卡顿白屏,JS加载过多)全部内容,希望文章能够帮你解决vue-cli3 项目打包优化(解决首屏卡顿白屏,JS加载过多)所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。