vue3.0学习笔记 (readonly深只读和shallowReadonly浅只读)

本文详细介绍了Vue3.0中`readonly`和`shallowReadonly`的用法。`readonly`确保了数据的全面深只读,不允许任何修改;而`shallowReadonly`则允许修改外层数据,仅对对象的顶层属性进行只读保护。这两种特性在防止数据意外修改的场景中非常有用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.readonly深只读  (全部深只读    不具备改的能力)

<template>
  <p>姓名:{
  { workObj.nameObj.names }}</p>

  <p>职业:{
  { workObj.work }}</p>

  <p>工资:{
  { workObj.wage }}</p>

  <button @click="changeClick">点击改变数据</button>
</template>

<script>
import { reactive, readonly} from "vue";

export default {

  setup() {
    //相当于vue2.0中的data  ref准备进行响应式
    let workObj = reactive({
      work: "前端工程师",
      wage: "30K",
      nameObj: { names: "张三" },
    });

    //点击改变数据的方法
    function changeClick() {
      workObj.work = "UI设计师";
      workObj.wage = "8K";
      workObj.nameObj.names = "李四";
    }

    //readonly深只读   重新赋值
    workObj = readonly(workObj);

    //最后return出去
    return {
      workObj,
      changeClick,
    };
  },
};
</script>


readonly全部没改变

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值