• vue3 的 ref、isRef、toRef、toRefs、toRaw 详细介绍


    ref、isRef、toRef、toRefs、toRaw 看着一堆类似的东西,一个头两个大,今天整理一篇文章详细介绍它们的功能及区别。

    1、ref

    ref 属性除了能够获取元素外,也可以使用 ref 函数,创建一个响应式数据,当数据值发生改变时,视图自动更新。

    复制代码
    
    
    复制代码

    2、isRef

    检查变量是否为一个被 ref 包装过的对象,如果是返回 true ,否则返回 false。

    复制代码
    import { ref, isRef, reactive } from 'vue'
    
    let str: string = ref('我是张三')
    let num: number = 1
    let per = reactive({ name: '代码女神', work: '程序媛' })
    
    console.log('strRes', isRef(str)) //true
    console.log('numRes', isRef(num)) //false
    console.log('perRes', isRef(per)) //false
    复制代码

    3、toRef

    创建一个 ref 对象,其 value 值指向另一个对象中的某个属性。

    toRef(obj, key) 将对象中的某个值转化为响应式数据,分为两种情况:

    • toRef 定义原始非响应式数据,修改值时,原始数据和 copy 数据都会变的,但是视图不更新。
    复制代码
    
    
    复制代码

     

        注意:如果是在 DOM 挂载之前调用 chang 方法,改变数值,此时数据和视图都会发生改变。

    • toRef 定义原始数据响应式数据,修改值时,原始数据,和 copy 数据都会改变,视图也会更新。
    复制代码
    
    
    复制代码

    最终值为 “李四”。

    4、toRefs

    toRefs 用来解构 ref、reactive 包裹的响应式数据。接收一个对象作为参数,遍历对象上的所有属性,将对象上的所有属性变成响应式数据。

    复制代码
    let obj = reactive({
      name: '姓名',
      age: 18,
    })
    let { name, age } = toRefs(obj)
    const chang = () => {
      name.value = '钻石王老五'
      age.value++
    }
    
    
    复制代码

    toRefs 解构数据时,如果某些参数作为可选参数,可选参数不存在时就会报错,如:

    复制代码
    let obj = reactive({
      name: '姓名',
      age: 18,
    })
    let { name, age, work } = toRefs(obj)
    const chang = () => {
      name.value = '钻石王老五'
      age.value++
      console.log('work', work.value)
      work.value = '程序媛'
    }
    复制代码

    此时可以使用 toRef 解决此问题,使用 toRef 解构对象某个属性时,先检查对象上是否存在该属性,如果存在就继承对象上的属性值,如果不存在就会创建一个。

    修改上边的代码为:

    复制代码
    let obj = reactive({
      name: '姓名',
      age: 18,
    })
    let { name, age } = toRefs(obj)
    let work = toRef(obj, 'work')
    const chang = () => {
      name.value = '钻石王老五'
      age.value++
      console.log('work', work.value)
      work.value = '程序媛'
    }
    复制代码

    5、toRaw

    将响应式对象转为原始对象。做一些不想被监听的事情,从 ref 或 reactive 得到原始数据。

    修改原响应式数据时,toRaw 转换得到的数据会被修改,视图也会更新,如:

    复制代码
    
    
    复制代码

    如果修改 toRaw 得到的原始数据,原数据也会被修改,但是视图不更新。如:

    复制代码
    
    
    复制代码

     

  • 相关阅读:
    [100天算法】-x 的平方根(day 61)
    php一维数组合并
    2.4GHz无线MCU芯片:CSM2433芯片 亿胜盈科
    RabbitMQ中CorrelationData 与DeliveryTag的区别
    Linux 软件包管理器 yum
    软件外包开发代码管理工具
    Java项目:毕业设计管理系统(java+SSM+JSP+jQuery+mysql)
    Spring Boot中 CommandLineRunner 与 ApplicationRunner作用、区别
    Linux文件权限管理:chomd命令和chown命令
    5、Docker安装mysql主从复制与redis集群
  • 原文地址:https://www.cnblogs.com/web-learn/p/16725393.html