【Vue3】vue3——setup,ref函数,reactive函数

简介: 【Vue3】vue3——setup,ref函数,reactive函数

💻 博主主页: 👉🏻 👉🏻 👉🏻 糖 -O-


👍👍👍 希望各位博主多多支持!!!


1.setup

组件中所用到的:数据、方法等等,均要配置在setup中

setup函数的两种返回值:

  • 若返回一个对象,则对象中的属性、方法, 在模板中均可以直接使用。(重点注意
    若返回一个渲染函数:则可以自定义渲染内容。

注意:

vue2可以读取vue3里面的数据

如果 vue2和vue3冲突,会用vue3的,所以

  1. 尽量不要与Vue2.x配置混用
  • Vue2.x配置(data、methos、computed…)中可以访问到setup中的属性、方法
  • 但在setup中不能访问到Vue2.x配置(data、methods、computed…)
  • 如果有重名, setup优先
  1. setup不能是一个async函数,因为返回值不再是return的对象, promise,
    模板看不到return对象中的属性


2.ref函数

可以定义一个响应式的数据

  • 语法:const xxx = ref(initValue)
  • JS中操作时: xxx.value
  • 模板中读取数据: 不需要.value,直接:

    {{xxx}}

  • 注:
  • 接收的数据可以是:基本类型、也可以是对象类型
  • 基本类型的数据:响应式依然是靠Object.defineProperty()getset完成的


3.reactive函数

一个对象类型的响应式数据(基本类型不要用它,要用ref函数)

const 代理对象= reactive(源对象)接收一个对象(或数组),返回一个代理对象(Proxy的实例对象,简称proxy对象)


4.Vue3.0中的响应式原理

vue2.x的响应式

  • 对象类型:通过Object.defineProperty()对属性的读取、修改进行拦截(数据劫持)
  • 数组类型:通过重写更新数组的一系列方法来实现拦截
Object.defineProperty(data, 'count', {
    get () {}, 
    set () {}
})

但是存在一些问题: 新增属性、删除属性, 界面不会更新; 直接通过下标修改数组, 界面不会自动更新。

Vue3.0的响应式

  • 通过Proxy(代理): 拦截对象中任意属性的变化, 包括:属性值的读写、属性的添加、属性的删除等
  • 通过Reflect(反射): 对源对象的属性进行操作
new Proxy(data, {
  // 拦截读取属性值
    get (target, prop) {
      return Reflect.get(target, prop)
    },
    // 拦截设置属性值或添加新属性
    set (target, prop, value) {
      return Reflect.set(target, prop, value)
    },
    // 拦截删除属性
    deleteProperty (target, prop) {
      return Reflect.deleteProperty(target, prop)
    }
})
proxy.name = 'tom'   


5.reactive对比ref

  • 从定义数据角度对比:
  • ref用来定义:基本类型数据
  • reactive用来定义:对象(或数组)类型数据
  • ref也可以用来定义对象(或数组)类型数据, 它内部会自动通过reactive转为代理对象
  • 从原理角度对比:
  • ref通过Object.defineProperty()getset来实现响应式
  • reactive通过使用Proxy来实现响应式(数据劫持), 并通过Reflect操作源对象内部的数据
  • 从使用角度对比:
  • ref定义的数据:操作数据需要.value,读取数据时模板中直接读取不需要.value
  • reactive定义的数据:操作数据与读取数据:均不需要.value
目录
相关文章
|
5天前
|
前端开发 JavaScript API
基于Vue3+Hooks实现4位随机数和60秒倒计时
本文介绍了如何在Vue3中使用Hooks API来实现生成4位随机数和执行60秒倒计时的功能,并提供了详细的代码示例和运行效果展示。
23 1
基于Vue3+Hooks实现4位随机数和60秒倒计时
|
1天前
|
JSON JavaScript 前端开发
Vue3在工作中使用的一些经验总结
这篇文章是关于Vue 3项目中使用TypeScript的一些经验总结,包括如何配置TSLint进行代码规范和类型检查,以及如何将现有的JavaScript代码迁移到TypeScript的步骤和注意事项。
Vue3在工作中使用的一些经验总结
|
4天前
|
JavaScript 算法 API
Vue 3有哪些新特性
【8月更文挑战第16天】Vue 3有哪些新特性
25 1
|
23小时前
|
JavaScript 前端开发 API
Vue3入门
Vue3入门
4 0
|
4天前
|
JavaScript
创建 Vue3 项目
创建 Vue3 项目
11 0
|
前端开发 API
Vue3入门到精通-setup
Vue3入门到精通-setup
|
4天前
|
JavaScript
如何创建一个Vue项目(手把手教你)
这篇文章是一篇手把手教读者如何创建Vue项目的教程,包括使用管理员身份打开命令行窗口、找到存放项目的位置、通过vue-cli初始化项目、填写项目信息、进入项目目录、启动项目等步骤,并提供了一些常见第三方库的引入方法。
如何创建一个Vue项目(手把手教你)
|
1天前
|
JavaScript
Vue学习之--------路由的query、params参数、路由命名(3)(2022/9/5)
这篇文章详细介绍了Vue路由中的query参数、命名路由、params参数以及props配置的使用方式,并通过实际项目案例展示了它们在开发中的应用和测试结果,同时解释了`<router-link>`的`replace`属性如何影响浏览器历史记录。
Vue学习之--------路由的query、params参数、路由命名(3)(2022/9/5)
|
1天前
|
JavaScript
Vue学习之--------VueX(2022/8/31)
这篇文章是关于VueX的基础知识介绍,涵盖了VueX中的state、mutations、getters和actions的定义和使用,以及Action提交mutation而非直接变更状态,以及mutations的同步执行特性。
Vue学习之--------VueX(2022/8/31)
|
1天前
|
JavaScript
Vue学习之--------深入理解Vuex之多组件共享数据(2022/9/4)
这篇文章通过一个实际的Vue项目案例,演示了如何在Vuex中实现多组件间共享数据。文章内容包括在Vuex的state中新增用户数组,创建Person.vue组件用于展示和添加用户信息,以及在Count组件中使用Person组件操作的数据。通过测试效果展示了组件间数据共享和状态更新的流程。
Vue学习之--------深入理解Vuex之多组件共享数据(2022/9/4)