uniapp项目vue2升级vue3简单记录
看到好多开源项目都升级了vue3,看文章说vue3性能升级很多,而且组合式api很香,遂把最近开发的自助洗车app升级下,在此记录下出现的问题。
- 我是先去vue官网看了下vue3的组合式api,有个大概了解,方便升级使用。
- 然后根据uniapp升级vue3官方指南把框架层面的先更改。
- 测试访问没问题后再做代码上的更改。(vue3兼容vue2的代码风格)
把代码风格改为组合式api
简单总结组合式api就是把原有的data,methods等等这些以前分开的代码块,都可以放在一起了,其他的刚开始不要多想。因为我第一遍在看vue官网的时候,看的稀里糊涂。
- vue2的data和mehtod代码:
data() {
return {
dataA: {},
dataB: [],
...
}
},
methods: {
methodA() {},
methodB() {},
...
}
vue3的data和mehtod写法:
import {ref,reactive,toRefs} from 'vue'
setup() {
#方式1(这是我刚开始的写法)
#这个写法有个很大的弊端就是如果我定义了很多data和method后,return代码会出现很长
#return{a,b,c,d,e,f,g........}
const dataA = ref({})
const dataB = ref([])
const methodA = () => {
#注意:必须加value
console.log(dataA.value);
}
const methodB = () => {}
#必须return出去才能在view中使用
return {dataA,dataB,methodA,methodB}
#方式2(创建一个对象包裹,最后只需要返回这个对象即可)
#方式2的代码更简洁且不需要加value,跟以前使用vue2区别不大。
const v3data = reactive({
dataA:{},
dataB:{},
methodA:() => {
#无需加value
console.log(v3data.dataA);
},
methodB:() => {}
})
return {
#只需这样返回即可,toRefs的作用自行搜索,这里不做解释。
...toRefs(v3Data)
}
}
- vue2中父子组件的调用方式
#parent.vue
<template>
<div>
<child ref="childRef" @myClick="onChildClick"/>
<Button type="primary" @click="parentClick">触发子组件方法</Button>
</div>
</template>
<script>
export default {
methods: {
parentClick() {
#父组件调用子组件方法
this.$childRef.childMethod()
},
onChildClick(){
console.log('子组件调用')
}
}
}
</script>
# child .vue
<template>
<div>
<h1>子组件</h1>
<Button type="primary" @click="sonClick">触发父组件方法</Button>
</div>
</template>
<script>
export default {
methods: {
sonClick () {
#子组件调用父组件
this.$emit('myClick');
},
childMethod(){
}
}
}
</script>
vue3中父子组件的调用方式
#parent.vue
<template>
<div>
<child ref="childRef" @myClick="onChildClick"/>
<Button type="primary" @click="parentClick">触发子组件方法</Button>
</div>
</template>
<script>
import {ref,reactive,toRefs} from 'vue'
export default {
setup() {
const v3data = reactive({
#在这里定义一个和子组件ref名称相同的对象置为null,vue会自动给赋值
childRef:null,
parentClick:()=>{
#父组件调用子组件方法
v3data.childRef.childMethod()
},
onChildClick:()=>{
console.log('子组件调用')
}
})
#这里一定要return出去,否则childRef一直为null
return {...toRefs(v3Data)}
}
}
</script>
# child .vue
<template>
<div>
<h1>子组件</h1>
<Button type="primary" @click="sonClick">触发父组件方法</Button>
</div>
</template>
<script>
import {ref,reactive,toRefs} from 'vue'
export default {
setup(props,context) {
const v3data = reactive({
sonClick () {
#子组件调用父组件
context.$emit('myClick');
},
childMethod(){
}
})
return {...toRefs(v3Data)}
}
</script>
- vue3中如何替代this(官方已不推荐,只作为知识点)
import {ref,getCurrentInstance} from 'vue'
export default {
#proxy相当于vue2的this
const {proxy} = getCurrentInstance()
}
网上说提升30%性能,或许我这个项目太小,没感到明显差距,不过组合式api确实是简单方便很多。
另外vue3废弃了filter,可以改用方法调用或者computed。
先写到这里,码字不易,如有错误,请指正。
uniapp项目vue2升级vue3简单记录的更多相关文章
- vue2升级vue3:vue2 vue-i18n 升级到vue3搭配VueI18n v9
项目从vue2 升级vue3,VueI18n需要做适当的调整.主要是Vue I18n v8.x 到Vue I18n v9 or later 的变化,其中初始化: 具体可以参看:https://vue- ...
- vue2升级vue3指南(二)—— 语法warning&error篇
本文总结了vue2升级vue3可能会遇到的语法警告和错误,如果想知道怎样升级,可以查看我的上一篇文章:vue2升级vue3指南(一)-- 环境准备和构建篇 Warning 1.deep /deep/和 ...
- vue2升级vue3:Vue Demij打通vue2与vue3壁垒,构建通用组件
如果你的vue2代码之前是使用vue-class-component 类组件模式写的.选择可以使用 https://github.com/facing-dev/vue-facing-decorator ...
- vue2升级vue3指南(一)—— 环境准备和构建篇
1.nodejs和npm 注意二者的版本,版本过低需要升级,本人升级后的版本如下: $ node -v v16.15.1 $ npm -v 8.11.0 2.package.json 和依赖升级 由于 ...
- Linux中java项目环境部署,简单记录一下
这里只是简单的记录一下linux环境下面如何快速的搭配好环境,使你的项目能在linux环境上面运行. 很多时候,我们都是用windows环境进行配置调试的,而真正很多服务器都是在linux服务器上面的 ...
- 初学做uniapp项目过程梳理的一些记录
1.uniapp不显示h5头部 第一种写法: { "path" : "pages/yunshi/yunshi", "style" : { & ...
- 前端项目 node8升级到node16,代码升级汇总
背景 公司的项目是vue项目,环境是node@8x版本的,最近我创建react hook的项目,发现至少需要node14才支持,打开官网才发现node都已经到16版本了.失策啊,失策.于是直接升级到最 ...
- Android项目框架升级尝鲜OkHttp
本文来自http://blog.csdn.net/liuxian13183/ ,引用必须注明出处! 随着项目日趋稳定,需求不再总是变化,那么是时间来整理下项目了.先简单介绍下,本项目最初使用loop4 ...
- 开源项目Material Calendar View 学习记录 (一)
开源项目Material Calendar View 学习记录 Github: https://github.com/prolificinteractive/material-calendarview ...
随机推荐
- Canvas 制作海报
HTML <template> <view class="content"> <view class="flex_row_c_c mod ...
- RStudio中文乱码
解决办法一: 1.设置RStudio文本显示的默认编码:RStudio菜单栏的Tools -> Global Options 2.code-->saving-->default te ...
- 【每日日报】第三十四天---Scanner类的应用
1 今天继续看书 Scanner类的应用 1 package File; 2 import java.util.Scanner; 3 4 public class ScannerDemo { 5 pu ...
- EMS已有用户分配邮箱方法
案例任务:已有域用户"test100",为该用户分配邮箱. 分配邮箱前,使用"get-user"命令确认用户类型.域用户"test100"的 ...
- c++对c的拓展_命名空间_简单使用
名字的控制:c可使用static关键字使该关键字在本单元内可见,c++则使用命名空间对名字的可见性及产生进行控制 命名空间:控制标识符的作用域(本质上就是一个作用域) 使用特点:1.必须定义在全局范围 ...
- mysql_install_db 一次修复密码
我用mysql 社区版进行的安装,在linux centos 操作系统下, yum install 方式系统默认安装时没有密码的,需要你及时设置,但是我操作多次后,并没有修改密码,启动和关闭多次以后就 ...
- drf的JWT认证
JWT认证(5星) token发展史 在用户注册或登录后,我们想记录用户的登录状态,或者为用户创建身份认证的凭证.我们不再使用Session认证机制,而使用Json Web Token(本质就是tok ...
- Go 语言字符串常见操作
@ 目录 1. 字节数组 2. 头尾处理 3. 位置索引 4. 替换 5. 统计次数 6. 重复 7. 大小写 8. 去除字符 9. 字符串切片处理 10. 数值处理 1. 字节数组 字节与字符的区别 ...
- CS基础课不完全自学指南
本文讲的是计算机学生怎么自学专业课,说长点就是该如何借助网络上已有的高质量学习资源(主要是公开课)来系统性的来点亮自己的CS技能树.这篇文章完全就是一篇自学性质的指南,需要对编程充满热情,起码觉得编程 ...
- Lab1:练习四——分析bootloader加载ELF格式的OS的过程
练习四:分析bootloader加载ELF格式的OS的过程. 1.题目要求 通过阅读bootmain.c,了解bootloader如何加载ELF文件.通过分析源代码和通过qemu来运行并调试bootl ...