手把手教你使用Vue2代码改成Vue3(图文详解)
时间:2021-09-27
来源:互联网
标签:
今天PHP爱好者给大家带来 之前的文章《一招教你使用vscode中插件搞定整个项目的代码替换(收藏)》中,给大家介绍了怎么使用vscode中插件搞定整个项目的代码替换。下面本篇文章给大家介绍怎么使用Vue2代码改成Vue3,伙伴们过来看看吧。 其实 迁移指南的地址:https://v3.cn.vuejs.org/guide/migration/array-refs.html 还有一些就改起来有点麻烦,比如自定义指令生命周期的更名,和传入参数的一些细微变化: 看到这种变化后,作为厌恶重复的程序员,已经开始盘算着能不能写个代码帮我们把这些规则批量给改好了,当然,写转换代码的代码要比写网页难上不少,还好我们之前已经有了一个趁手的工具:GoGoCode的地址https://github.com/thx/gogocode 于是我们梳理了迁移指南里提到的,附带上 迁移指南的地址:https://v3.cn.vuejs.org/guide/migration/array-refs.html 上面提到的两条 全局安装 在终端( 转换操作执行完毕后新的 我们拿 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 为了达成转换目的, 一些简单的规则,比如前面介绍的异步组件转换直接进行类似字符串的替换即可,由于是基于 这次项目也检验了 推荐学习:JS视频教程 以上就是手把手教你使用Vue2代码改成Vue3(图文详解)的详细内容,更多请关注php爱好者其它相关文章!
Vue3已经出来有一段时间了,很多朋友早已熟读了文档,写了好几个Demo,馋Composition API等新特性已久了。无奈,在实际工作中,大部分朋友还是不得不守着成千上万行的Vue2老项目过日子,做一次框架升级就像给老房子装修——念头总是充沛,决心总是匮乏。Vue团队已经尽可能地减少了破坏性更新,还提供了一份细致的迁移指南,条数不少,但定睛一看,大部分都是体力活,有些很简单,比如异步组件要多包上一层:

vue-router \ vuex升级的一些API变化,配合GoGoCode书写了近30条转换逻辑,涵盖了Vue2到Vue3代码break change的大部分场景,这个程序可以帮助你一键把Vue2的代码转换成Vue3的代码。Vue2到Vue3的差异对比中,右侧Vue3的代码就是通过这个工具根据左侧Vue2代码原片直出的,效果还不错吧 ^_^,我们来一起试一下!尝试一下
gogocode-clinpm 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)

实现比预想的要简单很多
GoGoCode新增支持了对。vue文件的解析,我们可以轻松地获取到解析好的template和scirpt AST节点,并利用 GoGoCode方便的API进行处理。AST的,所以无需关心代码格式,工作量是很小的:script
.replace('() => import($_$)', 'Vue.defineAsyncComponent(() => import($_$))')
.replace(
`
() => ({
component: import($_$1),
$$$
})`,
`
Vue.defineAsyncComponent({
loader: () => import($_$1),
$$$
})
`
);GoGoCode对复杂情况的处理,就像前面提到的自定义指令生命周期的变化,也很轻松地做到!
-
电脑出现normal.dotm错误怎么办?解决方法是什么? 时间:2025-12-15 -
normal.dotm在哪个文件夹里 如何删除normal模板 时间:2025-12-15 -
d3dll.dll不能启动怎么办?怎么修复? 时间:2025-12-15 -
psrpc.dll缺失的原因及解决方法 时间:2025-12-15 -
JavaScript插件Lightbox.js用法详解 时间:2025-12-15 -
isalpha()函数在Python中的用法详解 时间:2025-12-15
今日更新
-
欧易借贷功能操作指南:简单几步轻松借款
阅读:18
-
一耽漫画下载安装安卓最新版-一耽漫画app官方正版免费下载
阅读:18
-
学习通网页版账号快捷登录入口-学习通网页版一键直达学习主页
阅读:18
-
阿里旺旺官网直达入口-2026阿里旺旺官方首页最新网址一键获取
阅读:18
-
虫虫漫画入口官网-虫虫漫画官方正版免费阅读入口
阅读:18
-
微信文件传输助手网页版官网 最新登录入口
阅读:18
-
皮小妹是皮皮搞笑中的爆梗达人 魔性表情包女王 看完笑到停不下来
阅读:18
-
借款利率如何计算?最新贷款利息解析与省钱技巧
阅读:18
-
126邮箱官网入口-126邮箱免费注册官方正版
阅读:18
-
233乐园极速下载安装入口-233乐园官方正版免费下载安全通道
阅读:18










