Vue打包与配置问题
使用vue-cli3.0,本地开发没有问题,打包出现了各种问题。
1.yarn build不起作用
这个没得说,yarn不行,那就用npm run build进行打包吧。
2.css、js等的相对路径问题
默认的配置里面,css、js等文件都是用绝对路径进行引入的,打包后浏览html可能会出现js等资源找不到的情况,所以应该在vue.config.js中添加publicPath:’./‘,baseUrl已经废弃了。
3.页面空白
相对路径也弄好了,打开html查看也把js、css等文件下载下来了,可就是页面是个空白。
找来找去,发现是route配置的mode问题,将mode的histroy模式改掉就好了。
1.vue-cli npm run build空白页的两个坑 webpack gzip文件压缩优化打包文件
2.vue-cli npm run build后,页面空白没有任何报错
3.vue 3.0用history路由打包后出现空白页面,出现这个问题可以先检查两个方面 (检查的方式)
history模式下,二级目录配置了后台,还是出现了空白。
我尝试了很多方法,比如:参考文章2:
(1) 更改路由表的base
(2) 更改vue.config.js中的assetsDir
(3) 修改nginx配置
尝试过使用try_files,和rewrite进行重写,都达不到我想要的效果
1 | ## 面试系统手机端 |
1.vue history模式下出现空白页情况 (这个说的简单)
2.解决Vue项目使用history模式部署到nginx服务器下,非根目录下刷新页面空白的问题 (这里讲了三步,第一步更改Vue路由表配置,第二步更改Vue打包配置,第三步最后我们来更改nginx配置)
3.Vue - history模式上线后页面空白以及404 (这个不行)
4.vue 3.0用history路由打包后出现空白页面
5.vue-router history模式下刷新404问题 (这篇文章我尝试了第一种,是可以的,但是第二种,说的不详细,而且会报循环引用的错误:rewrite or internal redirection cycle while internally redirecting to “/dist/index.html”, client: 127.0.0.1, server: , request: “GET /dist HTTP/1.1”, host: “localhost:9092”)
还有要注意的就是在路由表的最下面,增加如下的内容,指定跳转路由
1 | { |
4.vue-cli3.x二级目录的部署说明
使用vue-router的hash模式的话,页面的url地址会显得很丑,于是我就想着使用history模式。刚开始想的,就是使用后台返回前端的index.html页面,但是这样后台和前台就要打包到一起了,特别是使用java的thymeleaf模板的时候,就要把前端的页面打包到resources目录下了,这样就违背了前后端分离的模式了。后来找到了使用nginx进行配置的方式,经过尝试,我最后明白了二级目录的具体含义。
主要部署步骤如下:(需要说明的就是dist这个目录,假如二级访问目录不是dist,就应该将router和publicPath中的内容,以及nginx中的dist改为自己的二级目录,比如:phdevicemobile)
1.一级目录的配置
修改nginx配置如下所示,root直接指向index.html的目录,然后使用try_files进行重新定向。
1 | server { |
1.vue history 模式打包部署在域名的二级目录的配置指南
2.使用nginx部署vue项目一直报错 (这里没啥大的用处)
3.vue路由history模式刷新页面出现404问题 (没啥用处)
2.配置为二级目录
(1) 修改router的base为:”/di”
(2) 修改vue.config.js中的publicPath为:”/di/“
(3) nginx配置如下:
1 | server { |
其中:
(1) try_files
try_files是挨个的往后尝试,前面的$uri没有,或者是$uri/ 目录没有,就自动重定向到最后一个@router变量上。
(2) rewrite
rewrite第一个 ^/(.*) 是正则表达式,匹配全部的地址,第二个是重定向的地址,第三个last有如下的选项:
1.vue-router history模式 nginx配置 (这个讲的是如何再根目录下进行配置,和我的需求有些不符合,我的是在某个location下)
2.vue history模式前后端分离项目nginx配置
3.try_files指令说明
4.nginx 中 index try_files location 这三个配置项的作用 (这里对于try_files讲的很明白了)
5.Nginx中的Rewrite的重定向配置与实践 (这个要关注公众号)
6.Nginx中的rewrite指令(break,last,redirect,permanent)
7.快速掌握Nginx(二) —— Nginx的Location和Rewrite (除了rewrite,还有一些其他的变量的说明)
8.Nginx中的Rewrite的重定向配置与实践
9.HTML5 History 模式 (官网给出的例子)
10.vue-router history模式在nginx二级目录下的配置 (这篇文章最后解决了我的问题,不过有一点就是vue的配置文件:config/index.js,改为:vue.config.js;assetsPublicPath,改为publicPath)
5.Some chunks are larger than 4000 kBs after minification.
在打包的时候,出现了这个问题,意思就是把所有的代码都进行了打包到了一个文件中。给出的建议是:
- Using dynamic import() to code-split the application
- Use build.rollupOptions.output.manualChunks to improve chunking: https://rollupjs.org/configuration-options/#output-manualchunks
- Adjust chunk size limit for this warning via build.chunkSizeWarningLimit.
【尝试】
我首先尝试了使用函数的形式,感觉这样的写法比较乱,我就没有采用。
1 | rollupOptions: { |
2.使用import,这个方法我没有尝试,比如使用下面的按需引入的方式进行加载。
1 | // 引入雷达图图表,图表后缀都为 Chart |
3.分解块,使用函数的形式,这样就是把很多的东西弄成了一个个的小块。
1 | manualChunks(id) { |
【解决方案】
我直接使用具名的方式解决了这个问题,比如将 mars3d 和 mars3d-cesium 进行了分块打包。
1 | build: { |
1.vite打包报错:块的大小超过限制,Some chunks are larger than 500kb after minification 两个解决方案:1.设置 build.chunkSizeWarningLimit。2.分解块,将大块分解成更小的块
2.动态导入
3.自定义构建
4.vite2 打包的时候vendor-xxx.js文件过大的解决方法 主要就是通过函数的形式进行区分,按照模块分开打包,大模块独立打包,小模块合并打包,这样就不会出现一大堆小文件了。
5.分析vite2.x/rollup分包原理,解决chunk碎片问题
6.记一次vite2.x打包优化过程 1.import()动态引入,我们依然可以看到把没有引入的模块打包进来了:还是可以看到 svg 渲染器、看到除了 radar 之外的组件。2.manualChunks:echarts: [‘echarts’]。3.优化legacy包,legacy的配置,是照搬其他项目的,考虑了 ie >= 11 版本的兼容。这个项目只需要考虑移动端,就可以不需要考虑 ie 了。