vue cli 3.0 迁移项目(下)
栏目: JavaScript · 发布时间: 5年前
内容简介:用公司的小项目,小小尝试之后,效果体验还不错。半年后鼓起勇气向领导谈及公司核心项目升级。领导说小小个个,胆子不小嘛。有这股劲,以后是个干大事的人。我领导是个
用公司的小项目,小小尝试之后,效果体验还不错。半年后鼓起勇气向领导谈及公司核心项目升级。领导说小小个个,胆子不小嘛。有这股劲,以后是个干大事的人。
我领导是个 java
,前端并不是他的拿手项目,很多时候他只能给我提供一个思想,实践需要我自己。慢慢自己去啃文档,慢慢踩坑,慢慢成长。
为什么要使用 vue cli 3.0
搭建项目?
为了更好的开发体验,提高开发效率,更好的了解项目。
之前写过一篇 vue cli 3.0 迁移项目(上)
的文章,比较了相关的性能,和配置文件。
这次讲讲项目迁移的具体操作
老项目是 vue cli 2.0
, 如何转到 vue cli 3.0
有没有风险?
我只知道项目平行迁移,搭建一个项目,然后把代码搬过去。风险和机遇共存,鼓起勇气向推动公司核心项目发展,很慌也很害怕。但是短暂的害怕可以换取长期极致的技术体验,加深对项目了解
,在推动技术的同时成长自己。稳赚不赔的买卖,任何时刻不要因为害怕而不去尝试。
有什么优缺点?
我司有四个后端研发团队,每个后端团队的都在不同的环境下进行开发,测试还有测试环境。各种环境算下来有10个,前端每一次在不同的环境下开发
都要去改配置文件。每次都是手动去改环境,很麻烦的。
之前的项目切换不同的环境,都是去 config/index.js
里面修改
解决方案: vue cli 2.0
的手脚架应该也是可以实现的,只是没有必要了。已经推进 vue cli 3.0
了,他构建的项目整体更加简洁,我更加喜欢。
实现了不同的命令行运行不同的环境也很方便,再也不要手动去修改配置文件了。
第一步设置环境变量和命令行
第二步配置文件里面读取环境变量
我用的是 webstorm
开发工具,借助 工具 命令自动配置,一键启动环境,再也不用手动输入了,哈哈哈,开心
项目大小和打包之后的大小,为了减少误差,这一次我上测试服务器看,没有在本地看了,不可思议的结果。
想知道运行速度,打包时间吗?动手自己去项目中体验吧。
使用场景怎么样?
不管是新项目还是老项目都适合,没有任何门槛。但是要注意的是,相关插件的升级和迁移。去遇见问题,去解决问题。多看文档,如果文档解决不了就去 issue
上面看看。
如果有解决不了的问题,那肯定是给的时间不够。整个升级都是我一个在负责的,利用的是业余时间,耗时有点久,请相信时间能解决很多问题的
踩坑小记
-
pm2
支持读取环境变量
这一次入坑主要是在 pm2
,因为之前不了解,这次踩坑花的时间特别长。一直 console.log()
把日志给打出来,去定位问题,一直 console.log
累死我了。哈哈
问题: 我们是通过 pm2 start process.json
命令启动项目的。
因为 pm2
运行的是打包之后的一堆 js
文件,所以是没有办法读取到打包之前的环境变量。这个问题可难道我了,想着 pm2
启动项目可以传入参数,那我是不是
可以通过传入参数给他去添加类似于环境变量的字符串。抱着是马当活马医试一试,结果成功了,笑死我了,开心的像个孩子
解决问题之后才发现原来这么简单,以后通过 pm2 start process.json --env prodution
pm2 start process.json --env hd
...就切换环境了。一次打包就够了,解决了多次打包的问题。
,因为之前小项目的环境变量是写死的,没有通过环境变量去读取,所以没有遇到问题。
这一次踩坑事件,设想以后在前端项目中加入 log4j
,可以实时监控错误日志,并且可以输出到指定文件。未来会尝试使用,好像人家公司都是有的。
- 项目中读取
static
文件失效
assets
和 static
文件夹的区别
两个放置静态资源的地方,分别是 src/assets
文件夹和 static
文件夹,这两者的区别很多人可能不太清楚,我就是其中一个。
assets
目录中的文件会被 webpack
处理解析为模块依赖,只支持相对路径形式。例如,在 <img src="./logo.png">
和 background: url(./logo.png)
中, "./logo.png"
是相对的资源路径,将由 Webpack
解析为模块依赖。
static/
目录下的文件并不会被 Webpack
处理:它们会直接被复制到最终的打包目录(默认是 dist/static
)下。必须使用绝对路径引用这些文件,这是通过在 config.js
文件中的 build.assetsPublicPath
和 build.assetsSubDirectory
连接来确定的。
简单说就是如果在项目中引入 static/
里面的文件通过 require()
进行引入。例如 require('../../../../static/img/ditu.jpg')
或者直接把 static
文件放到 public
地下。因为之前版本打包的时候 static
里面的文件是不会打包进去的。
升级之后的版本 pubilc
里面的文件是不会打包的。简单粗暴的解决就是 static
引入有问题,那我就 不打包 static
。哈哈,如果你们有更好的方法可以拿出来一起讨论呀
关于 vue cli 3.0
构建项目,或者迁移项目,最终还是要在是实际的项目开发中体验。每一个项目的实际情况都不一样,能去解决复杂的实际情况,才是关键所在。
关于升级到 vue cli 3.0
,现在在测试阶段,离上线的时间越来越近。或许还有不可预见的困难等待我去解决,一直秉持着去遇见问题,然后在解决他。
推动这次项目升级总体来说,学到了很多东西。
抽象的:
如何快速定位到问题,然后如何有效的解决问题?
项目在服务器上如何运行?
后端能实现,能解决的,前端也是可以的,需要不断的尝试?
技术得到了沉淀
具体的:
pm2
命令, Linux
命令
上公司服务器去看日志,修改查看项目想过信息
对公司项目了解程度上升了一个等级(如果不了解,怎么敢提出升级)
附一份 pm2
配置文件
{ "apps" : [ { "name" : "sunseeker", "script" : "./server.js", "log_date_format" : "YYYY-MM-DD HH:mm Z", "out_file" : "./logs/pm2-out.log", "error_file" : "./logs/pm2-err.log", "ignoreWatch" : ["[\\/\\\\]\\./", "node_modules"], "watch" : "false", "exec_mode" : "fork_mode", "env_production": { "NODE_ENV": "production", "VUE_APP_API" : "http://xxx.cn", "VUE_APP_GATE_API": "http:xxx.cn", "VUE_APP_XS_API" : "http:xxxx.cn" }, "env_hd": { "NODE_ENV": "hd", "VUE_APP_API" : "http://192.168.100.63:9050", "VUE_APP_GATE_API": "http://192.168.100.91:9053", "VUE_APP_XS_API" : "http://192.168.100.60:9051" }, "env": { "NODE_ENV": "development", "VUE_APP_API" : "http://192.168.0.209:9050", "VUE_APP_GATE_API": "http://192.168.0.222:9053", "VUE_APP_XS_API" : "http://192.168.0.241:9051" }, "env_dev-four": { "NODE_ENV": "dev-four", "VUE_APP_API" : "http://192.168.0.225:9050", "VUE_APP_GATE_API": "http://192.168.0.222:9053", "VUE_APP_XS_API" : "http://192.168.0.229:9051" }, "env_dev-one": { "NODE_ENV": "dev-one", "VUE_APP_API" : "http://192.168.0.183:9050", "VUE_APP_GATE_API": "http://192.168.0.142:9053", "VUE_APP_XS_API" : "http://192.168.0.169:9051" }, "env_dev-three": { "NODE_ENV": "dev-three", "VUE_APP_API" : "http://192.168.0.197:9050", "VUE_APP_GATE_API": "http://192.168.0.223:9053", "VUE_APP_XS_API" : "http://192.168.0.218:9051" }, "env_dev-two": { "NODE_ENV": "dev-two", "VUE_APP_API" : "http://192.168.0.185:9050", "VUE_APP_GATE_API": "http://192.168.0.151:9053", "VUE_APP_XS_API" : "http://192.168.0.194:9051" }, "env_md-test": { "NODE_ENV": "md-test", "VUE_APP_API" : "http://192.168.0.188:9050", "VUE_APP_GATE_API": "http://192.168.0.201:9053", "VUE_APP_XS_API" : "http://192.168.0.161:9051" }, "env_px-test": { "NODE_ENV": "px-test", "VUE_APP_API" : "http://192.168.0.137:9050", "VUE_APP_GATE_API": "http://192.168.0.140:9053", "VUE_APP_XS_API" : "http://192.168.0.141:9051" }, "env_xs-test": { "NODE_ENV": "xs-test", "VUE_APP_API" : "http://192.168.0.170:9050", "VUE_APP_GATE_API": "http://192.168.0.178:9053", "VUE_APP_XS_API" : "http://192.168.0.168:9051" }, "env_test": { "NODE_ENV": "test", "VUE_APP_API" : "http://192.168.0.185:9050", "VUE_APP_GATE_API": "http://192.168.0.151:9053", "VUE_APP_XS_API" : "http://192.168.0.194:9051" } } ] }
以上所述就是小编给大家介绍的《vue cli 3.0 迁移项目(下)》,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对 码农网 的支持!
猜你喜欢:- 迁移WPF项目到.NET CORE
- 银行项目从 SVN 迁移到 Git
- 闲鱼是这样高效稳定完成项目迁移的
- React 项目迁移 Webpack Babel7
- Apache 基金会宣布项目迁移到 GitHub
- [最全操作指南] 在线六个项目全部迁移Linux
本站部分资源来源于网络,本站转载出于传递更多信息之目的,版权归原作者或者来源机构所有,如转载稿涉及版权问题,请联系我们。
JavaScript编程精解
Marijn Haverbeke / 徐涛 / 机械工业出版社华章公司 / 2012-10-1 / 49.00元
如果你只想阅读一本关于JavaScript的图书,那么本书应该是你的首选。本书由世界级JavaScript程序员撰写,JavaScript之父和多位JavaScript专家鼎力推荐。本书适合作为系统学习JavaScript的参考书,它在写作思路上几乎与现有的所有同类书都不同,打破常规,将编程原理与运用规则完美地结合在一起,而且将所有知识点与一个又一个经典的编程故事融合在一起,读者可以在轻松的游戏式......一起来看看 《JavaScript编程精解》 这本书的介绍吧!