当前位置: 首页 > article >正文

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


http://www.kler.cn/a/148496.html

相关文章:

  • Linux 常用操作指令大揭秘(下)
  • 2024/11/13 英语每日一段
  • 深入理解接口测试:实用指南与最佳实践5.0(一)
  • Kubernetes在容器编排中的应用
  • 【设计模式】关联关系与依赖关系
  • 超子物联网HAL库笔记:定时器[外部模式]篇
  • 软工2021上下午第六题(组合模式)
  • 1.Spring源码解析-ClassPathXmlApplicationContext
  • Oracle
  • 线性表之队列
  • 【Qt绘制仪表盘】
  • CentOS7.9虚拟机EDA环境,支持模拟集成电路、数字集成电路、数模混合设计全流程,包含工艺库
  • LeetCode(33)最小覆盖子串【滑动窗口】【困难】
  • java BASE64Encoder BASE64Decoder 废弃
  • 大数据机房迁移该按照什么步骤进行 |数据中心
  • 【Java学习笔记】73 - 正则表达式
  • 算法通关村-----数据流的中位数
  • 企业源代码防泄密的有什么痛点及难点?
  • 安装MySQL搭建论坛
  • 通过测试驱动开发(TDD)的方式开发Web项目
  • Rust UI开发(一):使用iced构建UI时,如何在界面显示中文字符
  • 项目问题总结
  • 华为OD机试真题-整数对最小和-2023年OD统一考试(C卷)
  • 简要介绍Spring原生框架与Spring是轻量级框架的原因
  • 原生DOM事件、react16、17和Vue合成事件
  • Git控制指令