zoukankan      html  css  js  c++  java
  • 记一次 webpack 优化

    day 0 【项目概况】(2020-07-16)

    项目打包实在太慢了,打算长期优化一下。目前的打包时间(npm run build)约 60s(启动开发环境 npm run dev 也需要将近 50s)

    先介绍下项目,是个很普通的 vue 单页应用,年代比较久远,用的是 vue-cli2 脚手架,做了部分修改(根据备注是当时不修改打包报错),并没有刻意配置其他的优化项。看了下打包结果,100 多个文件(不包括 sourcemap 文件),项目的路由比较多,而且基本都是路由懒加载,所以打包出来的文件较多

    其中有几个文件比较大:

    vender.js 和 app.js 看起来是公共文件,app.css 是项目唯一的 css。而另外几个,猜测是路由懒加载打包的文件,但是为啥会这么大?留待分析

    此次优化,主要是优化 构建时间,同时也会对项目进行代码上的优化

    day 1 【项目依赖项整理】(2020-07-17)

    项目打包用的是 webpack3,对于优化的第一个想法是升级到 webpack4(webpack5 beta 已经好久了 ...),不管有没有用,用新不用旧。升级 webpack 意味着不少 loader 和插件都得同步升级,于是我看了下 package.json 文件,发现非常乱,不少没在项目中的依赖也出现在文件中,而且开发依赖和生产依赖混着来了

    经过整理,删除了以下依赖项:

    • awe-dnd(未使用,看起来是在 vue 中做拖拽的,两年没更新了,周下载也就 1500)
    • browser-sync(之前用了 gulp 脚本,现在未使用,同时删除了 gulpfile.js)
    • crypto(未使用)
    • font-awesome(未使用)
    • js-yaml(未使用)
    • gulp / gulp-autoprefixer / gulp-load-plugins / gulp-notify / gulp-plumber / gulp-sass (没必要再使用 gulp,而且实际上也没在使用了)
    • vue-easytable(未使用)
    • videojs-contrib-hls(未使用)
    • v-distpicker(不再使用)
    • vue-quill-editor(未使用)
    • vue-summernote(项目中使用的富文本编辑器,但是是整个文件夹复制过来的,所以没有使用 node_modules 里的)

    生产依赖中有几个存疑项:

    • mint-ui (并没有使用,好像是打入的第三方包使用了,那这个依赖不应该配置在第三方包中吗?)
    • ali-oss(啥玩意,到底有么有用呢)

    几个待优化项:(都是从代码优化角度,对于构建速度也有提升,但是应该提升不大)

    • bootstrap
    • jquery
    • mint-ui
    • moment
    • summernote / codemirror
    • ali-oss
    • merge(干嘛的?)
    • vue-resource
  • 相关阅读:
    在Dockerfile CMD一次执行多个命令
    文本中字符串替换
    centos登录密码正确但一直报login incorrect错误(错误赋予权限)
    kafka使用时的问题
    elasticsearch使用问题
    Redis常见问题
    tomcat常见问题
    JavaScript的BOM对象
    JavaScript的DOM操作
    JavaScript常用对象介绍
  • 原文地址:https://www.cnblogs.com/lessfish/p/13323822.html
Copyright © 2011-2022 走看看