VUE3-ref包裹object对象类型

VUE3-ref包裹object对象类型

ref不同类型下,实现的响应方式

基本类型 string number undefined null boolean

使用Object.defineProperty实现的

img

引用类型 object

// 如果你采用这种value直接赋值的方式,表示这种响应式是基于Object.defineProperty的
userRefImpl.value = {
  name: '张三',
  age: 50,
  addr: {
    city: '杭州1',
    street: '四季青街道1'
  }
}
// 下面这种使用value.的方式则使用的就是Proxy
// userRefImpl.value是一个代理对象Proxy: userProxy对象。
userRefImpl.value.name = '李四'
userRefImpl.value.age = '30'

// 修改地址信息
userRefImpl.value.addr.city = '上海'
userRefImpl.value.addr.street = '宁一路'

img

代码

<template>
  <div>计数:{{counterRefImpl}}</div>
  <button @click="counterRefImpl++">点我数字加一</button>
  <div>姓名:{{userRefImpl.name}}</div>
  <div>年龄:{{userRefImpl.age}}</div>
  <div>市区:{{userRefImpl.addr.city}}</div>
  <div>街道:{{userRefImpl.addr.street}}</div>
  <button @click="modifyUser">修改用户信息</button>
</template>
<script>
  import {
    ref
  } from 'vue'
  export default {
    setup() {
      // data
      // 如果ref包裹的是一个基本数据类型,响应式是如何实现的?Object.defineProperty
      let counterRefImpl = ref(100)
      console.log('ref_base', counterRefImpl);

      // 如果ref包裹的是一个对象,响应式是如何实现的?Object.defineProperty + Proxy 实现的
      // Proxy实现的响应式,对象中的对象,都有响应式处理
      let userRefImpl = ref({
        name: 'zhangsan',
        age: 21,
        addr: {
          city: '杭州',
          street: '四季青街道'
        }
      })
      console.log('ref_object', userRefImpl);

      function modifyUser() {
        // 这种修改时有响应式处理的
        counterRefImpl.value = 200

        // 对于userRefImpl对象来说,应该怎么改,才能有响应式呢?
        // 如果你采用这种value直接赋值的方式,表示这种响应式是基于Object.defineProperty的
        // userRefImpl.value = {
        //   name: '张三',
        //   age: 50,
        //   addr: {
        //     city: '杭州1',
        //     street: '四季青街道1'
        //   }
        // }

        // userRefImpl.value是一个代理对象Proxy: userProxy对象。
        userRefImpl.value.name = '李四'
        userRefImpl.value.age = '30'

        // 修改地址信息
        userRefImpl.value.addr.city = '上海'
        userRefImpl.value.addr.street = '宁一路'
      }
      return {
        counterRefImpl,
        userRefImpl,
        modifyUser
      }
    }
  }
</script>

文章涉及内容:
vue3、Proxy、Object.defineProperty

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值