提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档
文章目录
- 前言
- readonly
- 强行修改readonly:
前言
readonly:
让一个响应式数据变为只读的(深只读)。
shallowReadonly:
让一个响应式数据变为只读的(浅只读)。
应用场景: 不希望数据被修改时。
readonly
我们在代码中定义了一个响应式对象person 然后使用readonly(person )方法传入person 返回一个只读的对象 用p接收并返回
<template><div><h1>姓名:{{ name }}</h1><h2>年龄:{{ age }}</h2><h3>喜欢的水果:{{ likeFood.fruits.apple }}</h3><button @click="name += '~'">修改姓名</button><button @click="age++">修改年龄</button><button @click="likeFood.fruits.apple += '!'">修改水果</button></div>
</template><script>
import { reactive, toRefs, readonly } from "vue";
export default {name: "App",setup() {// 定义了一段数据let person = reactive({name: "张三",age: 18,likeFood: {fruits: {apple: "苹果",},},});// 使用了readonly将对象变为只读let p = readonly(person);console.log(p);// 将数据返回出去return {...toRefs(p),};},
};
</script>
强行修改readonly:
我们点击修改数据按钮 因为属性是只读的 所以浏览器提示无法修改此属性
shallowReadonly
使用shallowReadonly (person )方法传入person 返回一个只读的对象 用p接收并返回
<template><div><h1>姓名:{{ name }}</h1><h2>年龄:{{ age }}</h2><h3>喜欢的水果:{{ likeFood.fruits.apple }}</h3><button @click="name += '~'">修改姓名</button><button @click="age++">修改年龄</button><button @click="likeFood.fruits.apple += '!'">修改水果</button></div>
</template><script>
import { reactive, toRefs, shallowReadonly } from "vue";
export default {name: "App",setup() {// 定义了一段数据let person = reactive({name: "张三",age: 18,likeFood: {fruits: {apple: "苹果",},},});// 使用了shallowReadonly将对象变为只读let p = shallowReadonly(person);console.log(p);// 将数据返回出去return {...toRefs(p),};},
};
</script>
shallowReadonly强行修改结果:
因为apple是深层次的,不受管控
使用场景:
万一这个person的数据是别的组件定义传给你的,别的组件传给你只希望你使用不希望你修改的情况下,你怕自己组件内业务逻辑可能会修改它,所以用readonly和shallowReadonly函数去修饰,然后用readonly(person)包裹后新生成的person对象就可以达到效果了,哪怕你修改新生成person对象属性,也不会影响原有的person对象的属性。