vue2.0和vue3.0区别

vue2.0和vue3.0区别

双向数据绑定的原理改变:‌

Vue2使用Object.defineProperty对数据进行劫持,‌结合发布订阅模式实现双向数据绑定,‌而Vue3则采用了ES6的Proxy API对数据进行代理,‌提供了更多的拦截操作,‌能够监听到属性的删除和新增,‌相比Vue2,‌Vue3的这种实现方式更加高效和灵活。‌Vue3中要用ref包装,通过返回值的 .value属性获取响应式的值 ,修改也需要对 .value进行修改,( 注意在js中要.value,在模板html中解析时会自动添加.value,不需要添加).

html 复制代码
<template>
 <div>
<!-- 不需要.value -->
 {{ testOne }}
 {{ testTwo.directionD}}
 </div>
</template>
 
<script setup>
  const testOne= ref(0)
  
  const testTwo= ref({
    directionD: '',
    directionA: '',
    arr: []
  })
  
  const dataThree= ref({})
 
  // 使用需要.value
  console.log(testOne.value);
  console.log(dataThree.value);
  console.log(testTwo.value.directionD);
  console.log(testTwo.value.directionD);
 
</script>

支持碎片(Fragments):‌

Vue3支持在组件中拥有多个根节点,‌而Vue2则要求每个组件必须有一个单一的根节点。‌这一变化使得组件的结构设计更加灵活,‌减少了不必要的嵌套和复杂性。‌

引入Composition API:‌

Vue3引入了Composition API,‌这是一种新的API形式,‌允许开发者以函数的方式组织组件的逻辑,‌使得代码更加结构化和可重用。‌这与Vue2的Options API形成了鲜明的对比,‌后者通过对象的方式组织组件的选项。‌

语法和API的更新 :‌

Vue3在语法和API上做了一些调整,‌例如,‌样式穿透/deep/的选择器在Vue3中推荐使用()函数,‌而不是Vue2中的/deep/字符串。‌此外,‌Vue3还提供了更简洁和灵活的方式来绑定class和style,‌这些变化都是为了提升开发效率和代码的可读性。‌

css 复制代码
 <style lang="less" scoped>
/* vue2写法 */
/deep/.change {
  color: red;
}
</style>
<style lang="less" scoped>
/* vue3写法 */
:deep(.change ){
  color: red;
}
</style>

去除this

复制代码
    Vue3中没有this, 使用this报错 需要组件内的某个方法直接使用即可(注意使用的数据必须在调用前定义)

组件的生命周期:

指的是组件从创建->运行->销毁的整个过程,强调的是一个时间段。

大部分生命周期在vue2的周期前加 on 即可;vue3没有beforeCreate 和 created两个周期,那想在这两个周期中进行逻辑处理怎么办呢? setup中写好了调用即可👇

vue框架为组件内置了不同时刻的生命周期函数,生命周期函数会随着组件的运行而自动调用。如:①当组件在内存中被创建完毕之后,会自动调用created函数

②当组件被成功的渲染到页面上之后,会自动调用mounted函数

③当组件被销毁完毕之后,会自动调用unmounted函数

vue3中全部的生命周期函数:

数据共享的六种方法:

1.父子关系

①父->子 属性绑定

②子->父 事件绑定

③父<->子 组件上的v-model

2.兄弟关系

①eventBus

3.后代关系

①provide&&inject

4.全局数据共享

①vuex

自定义指令:

vue2中使用的是{bind,update},vue3中使用的是{mounted,updated}

相关推荐
繁依Fanyi1 分钟前
用 CodeBuddy 实现「IdeaSpark 每日灵感卡」:一场 UI 与灵感的极简之旅
开发语言·前端·游戏·ui·编辑器·codebuddy首席试玩官
黄鹂绿柳2 小时前
Vue+Vite学习笔记
vue.js·笔记·学习
来自星星的坤2 小时前
【Vue 3 + Vue Router 4】如何正确重置路由实例(resetRouter)——避免“VueRouter is not defined”错误
前端·javascript·vue.js
香蕉可乐荷包蛋6 小时前
浅入ES5、ES6(ES2015)、ES2023(ES14)版本对比,及使用建议---ES6就够用(个人觉得)
前端·javascript·es6
未来之窗软件服务7 小时前
资源管理器必要性———仙盟创梦IDE
前端·javascript·ide·仙盟创梦ide
liuyang___8 小时前
第一次经历项目上线
前端·typescript
西哥写代码8 小时前
基于cornerstone3D的dicom影像浏览器 第十八章 自定义序列自动播放条
前端·javascript·vue
清风细雨_林木木8 小时前
Vue 中生成源码映射文件,配置 map
前端·javascript·vue.js
FungLeo9 小时前
node 后端和浏览器前端,有关 RSA 非对称加密的完整实践, 前后端匹配的代码演示
前端·非对称加密·rsa 加密·node 后端
雪芽蓝域zzs9 小时前
JavaScript splice() 方法
开发语言·javascript·ecmascript