这篇文章主要为大家展示了“如何使用Vue2代码改成Vue3”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“如何使用Vue2代码改成Vue3”这篇文章吧。
Vue3
已经出来有一段时间了,很多朋友早已熟读了文档,写了好几个Demo
,馋Composition API
等新特性已久了。无奈,在实际工作中,大部分朋友还是不得不守着成千上万行的Vue2
老项目过日子,做一次框架升级就像给老房子装修——念头总是充沛,决心总是匮乏。
其实Vue
团队已经尽可能地减少了破坏性更新,还提供了一份细致的迁移指南,条数不少,但定睛一看,大部分都是体力活,有些很简单,比如异步组件要多包上一层:
迁移指南的地址:https://v3.cn.vuejs.org/guide/migration/array-refs.html
还有一些就改起来有点麻烦,比如自定义指令生命周期的更名,和传入参数的一些细微变化:
看到这种变化后,作为厌恶重复的程序员,已经开始盘算着能不能写个代码帮我们把这些规则批量给改好了,当然,写转换代码的代码要比写网页难上不少,还好我们之前已经有了一个趁手的工具:GoGoCode的地址https://github.com/thx/gogocode
于是我们梳理了迁移指南里提到的,附带上vue-router \ vuex
升级的一些API
变化,配合GoGoCode
书写了近30
条转换逻辑,涵盖了Vue2
到Vue3
代码break change
的大部分场景,这个程序可以帮助你一键把Vue2
的代码转换成Vue3
的代码。
迁移指南的地址:https://v3.cn.vuejs.org/guide/migration/array-refs.html
上面提到的两条Vue2
到Vue3
的差异对比中,右侧Vue3
的代码就是通过这个工具根据左侧Vue2
代码原片直出的,效果还不错吧 ^_^,我们来一起试一下!
全局安装gogocode-cli
npm install gogocode-cli -g
在终端(terminal
)中跳转到需要升级的Vue
项目路径。如果需要升级src
路径下的Vue
代码,执行如下命令
gogocode -s ./src -t gogocode-plugin-vue -o ./src-out
转换操作执行完毕后新的Vue3
代码会被写入到src-out
目录中
我们拿Vue2
的官方示例项目vue-hackernews-2.0
试了一下,发现在转换的基础上只要稍作改动再改一下构建流程就能跑起来了,一些转换的Diff
如下:(查看完整Diff
)
Vue2 的官方示例项目 vue-hackernews-2.0地址:https://github.com/vuejs/vue-hackernews-2.0
查看完整Diff地址:https://github.com/thx/gogocode/commit/6506a0e693aff1896da6c8863fa7e7c72d89610f?branch=6506a0e693aff1896da6c8863fa7e7c72d89610f&diff=split
这里只是简单地介绍,完整的方案请参考:https://gogocode.io/zh/docs/specification/vue2-to-vue3
为了达成转换目的,GoGoCode
新增支持了对。vue
文件的解析,我们可以轻松地获取到解析好的template
和scirpt AST
节点,并利用 GoGoCode
方便的API
进行处理。
一些简单的规则,比如前面介绍的异步组件转换直接进行类似字符串的替换即可,由于是基于AST
的,所以无需关心代码格式,工作量是很小的:
script .replace('() => import($_$)', 'Vue.defineAsyncComponent(() => import($_$))') .replace( ` () => ({ component: import($_$1), $$$ })`, ` Vue.defineAsyncComponent({ loader: () => import($_$1), $$$ }) ` );
这次项目也检验了GoGoCode
对复杂情况的处理,就像前面提到的自定义指令生命周期的变化,也很轻松地做到!
以上是“如何使用Vue2代码改成Vue3”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。