首页 > 其他分享 >【Vue2.0与Vue3.0区别总结】

【Vue2.0与Vue3.0区别总结】

时间:2022-12-27 14:02:40浏览次数:74  
标签:总结 const value 响应 Vue3.0 msg return ref Vue2.0

vue2.0和vue3.0区别

结构部分

  1. 程序主入口文件 main.js
  • vue2.0

【Vue2.0与Vue3.0区别总结】_初始化

  • vue3.0-暴露出 createApp方法

【Vue2.0与Vue3.0区别总结】_初始化_02

组件语法部分(vue3.0主要针对api的优化,vue3.0兼容vue2.0写法)

vue3.0 使用​​组合式api​​​,使用的地方在setup回调函数中,这个回调函数是创建组件之前执行,由于在执行 setup 时尚未创建组件实例,因此在 setup 选项中没有 this。​​这意味着,除了 props 之外,你将无法访问组件中声明的任何属性——本地状态、计算属性或方法。​


  1. 数据响应式 ref:ref 对我们的值创建了一个响应式引用。使用引用的概念将在整个组合式 API 中经常使用。
    在模板中解析会自动解开,直接使用。(<p>{{msg}}<p>);但是在js中必须(msg.value)
    reactive: 响应式转换是“深层”的——它影响所有嵌套 property。在基于 ES2015 Proxy 的实现中,返回的代理是不等于原始对象。建议只使用响应式代理,避免依赖原始对象
    对对象进行结构赋值会让对对象每一个属性失去响应式,所有在es6解构赋值前,可以通过toRefs方法包装
    toRefs: 将对象每个属性有具有响应式属性,并且带有ref特性;访问方式不同。可以解构赋值不影响数据的响应式
    readonly: 有时我们想跟踪响应式对象 (ref 或 reactive) 的变化,但我们也希望防止在应用程序的某个位置更改它。例如,当我们有一个被 provide 的响应式对象时,我们不想让它在注入的时候被改变。为此,我们可以基于原始对象创建一个只读的 Proxy 对象
    ref/reactive/toRefs 数据区别:

import { reactive, readonly } from 'vue'

const original = reactive({ count: 0 })

const copy = readonly(original)

// 在copy上转换original 会触发侦听器依赖

original.count++

// 转换copy 将导失败并导致警告
copy.count++ // 警告: "Set operation on key 'count' failed: target is readonly.
  • vue2.0 选项式api

  • data() {
    return {
    msg: "初始化"
    }
    },
    methods: {
    changeHandle() {
    this.msg = "改变的"
    }
    },


  • vue3.0 组合式api

  • setup() {
    let msg = ref("初始化");//string number
    let person = reactive({name:"lisi",age:20})// object array
    const changeHandle = () => { msg.value = "改变的" }
    const changeHandle2 = () => { person.age = 30 }
    return {
    msg,
    changeHandle,
    changeHandle2
    }
    },


  1. watch使用
  • vue2.0 选项式api
watch: {
//普通的
msg:{
handler(newValue,oldValue) {
console.log("....")
}
},
//深度
person:{
handler(newValue,oldValue) {

},
immediate:true,
deep:true
}
},

*vue3.0 组合式api

setup() {
let msg = ref("初始化");//string number
let person = reactive({name:"lisi",age:20})// object array
watch(msg,(newValue,oldValue)=>{
console.log(this);//undefined;箭头函数绑定父级作用域的上下文,所以this不会指向当前的组件
console.log(newValue,oldValue);
},{deep:false,immediate:false})

watch(() => person.age,(newValue,oldValue) => {
console.log(newValue,oldValue)
})
return {
msg

}
},
  1. computed使用
computed:{
//无参数
filterMsg() {
return this.msg + "999"
},
//有参数
filterMsg2(number) {
return function() {
return this.msg + number;
}
},
// 自定义set方法
filterMsg3: {
get() {
return this.msg + "999"
},
set(value) {
...
}
}
}
  • vue3.0
//无参数
const filterMsg =computed( () => msg.value + "fdfasdf")
//有参数
const filterMsg2 =computed(() => {
return function(num) {
return msg.value + num
}
})
// 自定义set方法和get方法
const count = ref(1)
const plusOne = computed({
get: () => count.value + 1,
set: val => {
count.value = val - 1
}
})

plusOne.value = 1
console.log(count.value) // 0

组件间的通信

在了解组件通信之前,我们先要深入了解setup,render方法,this,。

setup

  1. props
    表示组件传入当前组件的props值,响应式的,当传入新的prop时,它将被更新,可以通过watch监听到变化。


注意:

但是,因为 props 是响应式的,你不能使用 ES6 解构,因为它会消除 prop 的响应性。
我们可以通过 toRefs方法完成可以解构赋值,且不影响属性的响应式
import { toRefs } from 'vue'

setup(props) {
const { title } = toRefs(props)

console.log(title.value)
}


  1. context 上下文
    传递给 setup 函数的第二个参数是 context。context 是一个普通的 JavaScript 对象,它暴露三个组件的 property:
// MyBook.vue
export default {
setup(props, { attrs, slots, emit }) {
...
}
}


渲染函数

setup() {
const num = ref(100);//添加包装引用对象
const person = reactive({name:"lisi",age:20});//本身就是响应式对象
const person2 = toRefs(person);//对对象每一个属性添加包装引用
console.log(person2)
return () => h("div", [num.value,person.name,person2.age.value])
}


标签:总结,const,value,响应,Vue3.0,msg,return,ref,Vue2.0
From: https://blog.51cto.com/u_15874356/5972718

相关文章

  • 传奇开服教程——总结19条对待玩家的经验!
    ​1、不要开在线活动,特别是GM亲自刷怪的活动这一点是引起很多事故,比如真人PK,GM被骂,还有强烈影响了游戏的公平性,你想拉玩家?错误!你将会感觉到“累死不讨好”、“赔了夫人......
  • rapidjson使用总结
    目录​​(?)​​​​[-]​​​​rapidjson简介​​​​Dom解析示例​​rapidjson简介rapidjson是腾讯的开源json解析框架,用c++实现。由于全部代码仅用headerfile实现,所以很......
  • 【基于物理的渲染(PBR)白皮书】(二) PBR核心理论与渲染光学原理总结
    这是【基于物理的渲染(PBR)白皮书】系列的第二篇文章。按照既定规划,本文将主要关注基于物理的渲染的核心理论与渲染的光学原理,以在整个系列中起到理论支柱的作用。从本文内容......
  • 实习总结(第六天)
    昨天晚上得到了一些数据,今天主要的任务是把这些数据测试一下,再熟悉一下软件的具体流程。首先梳理了一下文件上传功能的bug1、在上传的时候,第一次上传通常会失败,第二次再......
  • 【基于物理的渲染(PBR)白皮书】(三)迪士尼原则的BRDF与BSDF相关总结
    基于物理的渲染(PhysicallyBasedRendering,PBR)技术,自迪士尼在SIGGRAPH2012上提出了著名的“迪士尼原则的BRDF(DisneyPrincipledBRDF)”之后,由于其高度的易用性以及方便......
  • 大数据知识挖宝行动,总结与归类公众号的历史文章
    虽说一些稿子、挖掘的优秀知识内容文章存了不少,但是决定今天利用中午吃饭一个小时做一个归类与盘点,同时也为了朋友们方便阅读与查找。公众号的历史文章包含六个系列,原创文章......
  • 关于UIWebView和PhoneGap的总结
    前言今天参加了Adobe组织的一个关于​​PhoneGap的开发讲座​​ ,而PhoneGap在iOS设备上的实现就是通过UIWebView控件来展示html内容,并且与native代码进行交互的。正好我......
  • 迟到的年度总结-数据的人生
    新一年首月将要尾声,一个令人不太想要总结的年份。在这不同寻常的一年里,人类经历了一场没有硝烟的战争,新冠抗疫战争弥漫的烟火直到2021年仍然在继续。疫情的出现,几乎让中国这......
  • 迟到的年度总结-数据的人生
    新一年首月将要尾声,一个令人不太想要总结的年份。在这不同寻常的一年里,人类经历了一场没有硝烟的战争,新冠抗疫战争弥漫的烟火直到2021年仍然在继续。疫情的出现,几乎让中国这......
  • 用一个词来总结即将过去的2017年~"本号还活着"
    我活着吗?我还活着!!! 从2016活到了2017,从望京活到了村里,伴随着豆荚到土豆到大鱼,习惯了人来人往,也习惯了分分合合,唯独自己身边一起战斗的战友,没有舍得丢弃一个!吃饭时,好些人偶......