vue项目实现减少app.js和vender.js的体积操作


Posted in Javascript onNovember 12, 2020

配置webpack中externals来减少打包后vendor.js的体积

在日常的项目开发中,我们会用到各种第三方库来提高效率,但随之带来的问题就是打包后的vendor.js体积过大,导致加载时空白页时间过长,给用户的体验太差。为此我们需要减少vendor.js的体积,从本质上来解决这种问题。

webpack的外部扩展(externals)可以有效的解决。

externals 配置选项提供了「从输出的 bundle 中排除依赖」的方法。相反,所创建的 bundle 依赖于那些存在于用户环境(consumer's environment)中的依赖。防止将某些 import 的包(package)打包到 bundle 中,而是在运行时(runtime)再去从外部获取这些扩展依赖(external dependencies)。

webpack之externals官方参考文档传送门,请戳这里→ externals

下面就以Vue项目为例,介绍一下externals的使用。项目中引用了vue、vue-router、axios、element-ui、qs等第三方库,那么我们的目标就是把这些从输出的 bundle 中排除依赖。

1、在/build/webpack.base.conf.js中,配置externals

// externals中的key是后面需要require的名字,value是第三方库暴露出来的方法名
module.exports = {
 //...
 externals: {
 'vue': 'Vue',
 'vue-router': 'VueRouter',
 'axios': 'axios',
 'element-ui': 'Element',
 'qs': 'Qs'
 }
}

2、在/src/main.js和/src/router/index.js中,移除上面与之相关的import引入,改为require方式引入

// /src/main.js
// 移除
import Vue from 'vue'
import ElementUI from 'element-ui'
import 'element-ui/lib/theme-chalk/index.css'
import axios from 'axios'
import Qs from 'qs'
Vue.use(ElementUI)
// 添加
const Vue = require('vue')
const ElementUI = require('element-ui')
const axios = require('axios')
const Qs = require('qs')
// /src/router/index.js
// 移除
import Router from 'vue-router'
Vue.use(Router)
// 添加
const Router = require('vue-router')

3、在/index.html中,通过CDN引入相应的js文件和css文件(CDN地址:https://www.bootcdn.cn)

.选用unpkg来作为第三方提供.如我想要axios包则输入网址为 https://unpkg.com/axios/ (末尾加斜杠代表你要查询该库的所有版本列表).然后你可以选择对应的版本如https://unpkg.com/axios@0.18.0/index.js 。其中 @0.18.0为库的版本号,若不写则默认最新版本.

<html>
 <head>
 <meta charset="utf-8">
 <meta name="viewport" content="width=device-width,initial-scale=1.0">
 <link href="https://cdn.bootcss.com/element-ui/2.3.8/theme-chalk/index.css" rel="external nofollow" rel="stylesheet">
 <title>配置webpack中externals来减少打包后vendor.js的体积</title>
 </head>
 <body>
 <div id="app"></div>
 <script src="https://cdn.bootcss.com/vue/2.5.15/vue.min.js"></script>
 <script src="https://cdn.bootcss.com/vue-router/3.0.1/vue-router.min.js"></script>
 <script src="https://cdn.bootcss.com/axios/0.18.0/axios.min.js"></script>
 <script src="https://cdn.bootcss.com/element-ui/2.3.8/index.js"></script>
 <script src="https://cdn.bootcss.com/qs/6.5.2/qs.min.js"></script>
 </body>
</html>

4 代码打包成压缩包,浏览器支持自动解压的将会加载压缩包

在config\index.js中进行修改

productionGzip: true,

//需要下载相应的包 npm install --save-dev compression-webpack-plugin

补充知识:Vue打包之后会出现map文件,体积很大

build命令后占体积最大的竟然是.map文件,webpack如何设置不让编译出.map文件呢?

解决办法:去config/index.js中改一个参数:

productionSourceMap:false

把这个改为false。不然在最终打包的文件中会出现一些map文件

map文件的作用:项目打包后,代码都是经过压缩加密的,如果运行时报错,输出的错误信息无法准确得知是哪里的代码报错。

有了map就可以像未加密的代码一样,准确的输出是哪一行哪一列有错。

以上这篇vue项目实现减少app.js和vender.js的体积操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JQuery 表单中textarea字数限制实现代码
Dec 07 Javascript
百度Popup.js弹出框进化版 拖拽小框架发布 兼容IE6/7/8,Firefox,Chrome
Apr 13 Javascript
javascript中关于执行环境的杂谈
Aug 14 Javascript
ejs v9 javascript模板系统
Mar 21 Javascript
JavaScript组合模式学习要点
Aug 26 Javascript
用jQuery实现可输入多选下拉组合框实例代码
Jan 18 Javascript
jQuery源码分析之init的详细介绍
Feb 13 Javascript
为vue-router懒加载时下载js的过程中添加loading提示避免无响应问题
Apr 03 Javascript
angular中子控制器向父控制器传值的实例
Oct 08 Javascript
详解iframe跨域的几种常用方法(小结)
Apr 29 Javascript
vue App.vue中的公共组件改变值触发其他组件或.vue页面监听
May 31 Javascript
vue实现吸顶、锚点和滚动高亮按钮效果
Oct 21 Javascript
详解vue 组件的实现原理
Nov 12 #Javascript
Vant Weapp组件踩坑:picker的初始赋值解决
Nov 12 #Javascript
vue 图片裁剪上传组件的实现
Nov 12 #Javascript
js前端传json后台接收‘‘被转为quot的问题解决
Nov 12 #Javascript
使用Vant完成DatetimePicker 日期的选择器操作
Nov 12 #Javascript
JavaScript 实现拖拽效果组件功能(兼容移动端)
Nov 11 #Javascript
vant 中van-list的用法说明
Nov 11 #Javascript
You might like
一步一步学习PHP(5) 类和对象
2010/02/16 PHP
PHP中__get()和__set()的用法实例详解
2013/06/04 PHP
使用gd库实现php服务端图片裁剪和生成缩略图功能分享
2013/12/25 PHP
php中JSON的使用方法
2015/04/30 PHP
YII Framework框架教程之缓存用法详解
2016/03/14 PHP
PHP swoole和redis异步任务实现方法分析
2019/08/12 PHP
Jquery乱码的一次解决过程 图解教程
2010/02/20 Javascript
实例说明为什么不要行内使用javascript
2014/04/18 Javascript
JavaScript控制两个列表框listbox左右交换数据的方法
2015/03/18 Javascript
Boostrap入门准备之border box
2016/05/09 Javascript
js基于cookie方式记住返回页面用法示例
2016/05/27 Javascript
jquery 无限极下拉菜单的简单实例(精简浓缩版)
2016/05/31 Javascript
关于JS 预解释的相关理解
2016/06/28 Javascript
利用Plupload.js解决大文件上传问题, 带进度条和背景遮罩层
2017/03/15 Javascript
使用 Node.js 对文本内容分词和关键词抽取
2017/05/27 Javascript
如何获取TypeScript的声明文件.d.ts
2018/05/01 Javascript
JavaScript函数式编程(Functional Programming)组合函数(Composition)用法分析
2019/05/22 Javascript
JavaScript 接口原理与用法实例详解
2020/05/12 Javascript
python实现中文输出的两种方法
2015/05/09 Python
python通过get,post方式发送http请求和接收http响应的方法
2015/05/26 Python
简单了解Python下用于监视文件系统的pyinotify包
2015/11/13 Python
python3中dict(字典)的使用方法示例
2017/03/22 Python
Tensorflow 训练自己的数据集将数据直接导入到内存
2018/06/19 Python
python调用matlab的m自定义函数方法
2019/02/18 Python
Python封装成可带参数的EXE安装包实例
2019/08/24 Python
新手入门学习python Numpy基础操作
2020/03/02 Python
Python+unittest+DDT实现数据驱动测试
2020/11/30 Python
巴西Mr. Cat在线商店:购买包包和鞋子
2019/09/08 全球购物
装潢设计实习自我鉴定
2013/09/19 职场文书
教师专业理论水平的自我评价分享
2013/11/09 职场文书
2014年上半年工作自我评价
2014/01/18 职场文书
乡镇交通安全实施方案
2014/03/29 职场文书
初三新学期计划书
2014/05/03 职场文书
2014国庆节国旗下演讲稿(精选版)
2014/09/26 职场文书
关于党风廉政建设宣传教育月的活动总结!
2019/08/08 职场文书
DIV CSS实现网页背景半透明效果
2021/12/06 HTML / CSS