Vue 定义只读数据 readonly 与 shallowReadonly

readonly 让一个响应式数据变为 **深层次的只读数据**。

shallowReadonly 让一个响应式数据变为 **浅层次的只读数据**,只读第一层。

isReadonly 判断一个数据是不是只读数据。

应用场景:不希望数据被修改时使用。


readonly深层次只读:

<template>
  <h1>reactive数据</h1>
  <p>姓名:{{ info.name }}</p>
  <p>年龄:{{ info.age }}</p>
  <button @click="editInfo">修改reactive数据</button>
  <hr />
  <h1>readonly数据</h1>
  <p>姓名:{{ readInfo.name }}</p>
  <p>年龄:{{ readInfo.age }}</p>
  <button @click="editReadInfo">修改readonly数据</button>
</template>

<script>
// 引入 readonly 与 reactive 函数
import { readonly, reactive } from 'vue'
export default {
  name: "Home",
  setup() {
    // 使用 reactive 创建数据
    const info = reactive({
      name: "张三",
      age: 20
    });
    // 使用 readonly 创建只读数据
    const readInfo = readonly(info);
    // 修改 reactive 数据
    const editInfo = () => {
      info.name = "李四";
      info.age = 22;
      console.log(info);
      console.log(readInfo);
    }
    // 修改 readonly 数据(警告,不会被修改)
    const editReadInfo = () => {
      readInfo.name = "李四";
      readInfo.age = 22;
      console.log(info);
      console.log(readInfo);
    }
    // 返回数据
    return {
      info,
      readInfo,
      editInfo,
      editReadInfo
    }
  }
}
</script>

:修改原数据时,只读的数据也会发生改变。

:修改只读的数据时,会触发警告提示数据不允许被修改。 

:readonly 返回的数据是不允许被修改的,但是可以修改原来的数据。并且原来的数据发生改变时,readonly 返回的数据也会发生改变。 

 shallowReadonly 浅层次只读:

<template>
  <h1>readonly数据</h1>
  <p>姓名:{{ readInfo.name }}</p>
  <p>商品名称:{{ readInfo.shop.title }}</p>
  <p>商品价格:{{ readInfo.shop.price }}</p>
  <button @click="editReadInfo">修改readonly数据</button>
  <hr />
  <h1>shallowReadonly数据</h1>
  <p>姓名:{{ shallowInfo.name }}</p>
  <p>商品名称:{{ shallowInfo.shop.title }}</p>
  <p>商品价格:{{ shallowInfo.shop.price }}</p>
  <button @click="editShallowInfo">修改shallowReadonly数据</button>
  <hr />
</template>

<script>
// 引入 readonly、shallowReadonly、reactive 函数
import { readonly, shallowReadonly, reactive } from 'vue'
export default {
  name: "Home",
  setup() {
	// 使用 reactive 创建数据
    const readData = reactive({
      name: "张三",
      shop: {
        title: "灰太狼",
        price: 999
      }
    })
    // 使用 readonly 定义深层次的只读数据
    const readInfo = readonly(readData);
    // 使用 reactive 创建数据
    const shallowData = reactive({
      name: "李四",
      shop: {
        title: "喜洋洋",
        price: 666
      }
    })
    // 使用 shallowReadonly 定义浅层次的只读数据
    const shallowInfo = shallowReadonly(shallowData);
    // 修改 readonly 数据
    const editReadInfo = () => {
      readInfo.name = "张三丰";
      readInfo.shop.title = "红太狼";
      readInfo.shop.price = "199";
      console.log(readInfo);
    }
    // 修改 shallowReadonly 数据
    const editShallowInfo = () => {
      shallowInfo.name = "李四民";
      shallowInfo.shop.title = "懒洋洋";
      shallowInfo.shop.price = "166";
      console.log(shallowInfo);
    }
    // 返回数据
    return {
      readInfo,
      shallowInfo,
      editReadInfo,
      editShallowInfo,
    }
  }
}
</script>

当修改 readonly 数据时,不论多少层,都不允许被修改。

当修改 shallowReadonly 数据时,只有第一层不允许被修改,第二层及以后的数据是可以被修改的。 

原创作者:吴小糖

创作时间:2023.11.28

  • 3
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 2
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

小吴吴吴呀

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值