经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » JS/JS库/框架 » Vue.js » 查看文章
vue?代码压缩优化方式
来源:jb51  时间:2022/3/29 8:44:16  对本文有异议

vue代码压缩优化

设置productionSourceMap为false

如果不需要生产环境的 source map,可以将其设置为 false 以加速生产环境构建。

设置为false打包时候不会出现.map文件

  1. module.exports = {
  2. ? ? productionSourceMap: false
  3. }

代码压缩

安装uglifyjs-webpack-plugin插件,可以去除项目中console.log和debugger 

  1. npm install uglifyjs-webpack-plugin --save
  2. const UglifyJsPlugin = require('uglifyjs-webpack-plugin')
  3. // 生产环境相关配置
  4. if (isProduction) {
  5. ? ? // 代码压缩
  6. ? ? config.plugins.push(
  7. ? ? ? ? new UglifyJsPlugin({
  8. ? ? ? ? ? ? uglifyOptions: {
  9. ? ? ? ? ? ? ? ? //生产环境去除console等信息
  10. ? ? ? ? ? ? ? ? compress: {
  11. ? ? ? ? ? ? ? ? ? ? warnings: false, // 若打包错误,则注释这行
  12. ? ? ? ? ? ? ? ? ? ? drop_debugger: true,//是否移除debugger
  13. ? ? ? ? ? ? ? ? ? ? drop_console: true,
  14. ? ? ? ? ? ? ? ? ? ? pure_funcs: ['console.log']//移除console
  15. ? ? ? ? ? ? ? ? }
  16. ? ? ? ? ? ? },
  17. ? ? ? ? ? ? sourceMap: false,
  18. ? ? ? ? ? ? parallel: true
  19. ? ? ? ? })
  20. ? ? )
  21. }

图片资源压缩

 安装 image-webpack-loader 插件,可以将大图片进行压缩从而缩小打包体积 

  1. npm install image-webpack-loader --save
  2. ? ? chainWebpack: config => {
  3. ? ? ? ? // ============压缩图片 start============
  4. ? ? ? ? config.module
  5. ? ? ? ? ? ? .rule('images')
  6. ? ? ? ? ? ? .use('image-webpack-loader')
  7. ? ? ? ? ? ? .loader('image-webpack-loader')
  8. ? ? ? ? ? ? .options({ bypassOnDebug: true })
  9. ? ? ? ? ? ? .end()
  10. ? ? ? ? // ============压缩图片 end============
  11. ? ? }

开启gzip压缩

开启gzip压缩,可以优化http请求,提高加载速度 

  1. npm install compression-webpack-plugin --save-dev
  2. const CompressionPlugin = require("compression-webpack-plugin");
  3. // 开启gzip压缩
  4. config.plugins.push(new CompressionPlugin({
  5. ? ? algorithm: 'gzip',
  6. ? ? test: new RegExp("\\.(" + ["js", "css"].join("|") + ")$"), // 匹配文件扩展名
  7. ? ? // threshold: 10240, // 对超过10k的数据进行压缩
  8. ? ? threshold: 5120, // 对超过5k的数据进行压缩
  9. ? ? minRatio: 0.8,
  10. ? ? cache: true, // 是否需要缓存
  11. ? ? deleteOriginalAssets:false ?// true删除源文件(不建议);false不删除源文件
  12. ?}))

vuecli3代码压缩混淆

最近被某大公司大佬虐了,要求混淆用vuecli3写的代码(啥敏感信息都没有,混淆个什么混淆...)

现将混淆流程记录如下

1、安装 “uglifyjs-webpack-plugin”

  1. cnpm i --save uglifyjs-webpack-plugin

没有安装cnpm的同学可以用npm

2、在项目根目录下创建一个名为 vue.config.js的文件

3、在vue.config.js中引入uglifyjs-webpack-plugin

  1. const UglifyPlugin = require('uglifyjs-webpack-plugin')

4、在vue.config.js中配置uglifyjs-webpack-plugin

  1. module.exports = {
  2. ? configureWebpack: (config) => {
  3. ? ? if (process.env.NODE_ENV == 'production') {
  4. ? ? ? // 为生产环境修改配置
  5. ? ? ? config.mode = 'production'
  6. ? ? ? // 将每个依赖包打包成单独的js文件
  7. ? ? ? let optimization = {
  8. ? ? ? ? minimizer: [new UglifyPlugin({
  9. ? ? ? ? ? ? uglifyOptions: {
  10. ? ? ? ? ? ? ? ? warnings: false,
  11. ? ? ? ? ? ? ? ? compress: {
  12. ? ? ? ? ? ? ? ? ? drop_console: true,?
  13. ? ? ? ? ? ? ? ? ? drop_debugger: false,
  14. ? ? ? ? ? ? ? ? ? pure_funcs: ['console.log']?
  15. ? ? ? ? ? ? ? ? }
  16. ? ? ? ? ? ? }
  17. ? ? ? ? ?})]
  18. ? ? ? }
  19. ? ? ? Object.assign(config, {
  20. ? ? ? ? optimization
  21. ? ? ? })
  22. ? ? } else {
  23. ? ? ? // 为开发环境修改配置
  24. ? ? ? config.mode = 'development'
  25. ? ? }
  26. ? }
  27. };

这就可以了,接下来大家可以打包试试了

  1. cnpm run build

如果报错的话,估计是uglifyjs-webpack-plugin版本又更新了,可能需要修改配置中的 “minimizer”节点,官方文档地址:https://www.npmjs.com/package/uglifyjs-webpack-plugin

以上为个人经验,希望能给大家一个参考,也希望大家多多支持w3xue。

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号