readonly 与 shallowReadonly
- readonly: 让一个响应式数据变为只读的(深只读)。
- shallowReadonly:让一个响应式数据变为只读的(浅只读)。
- 应用场景: 不希望数据被修改时。
示例:
<template> <h4>当前求和为:{{sum}}</h4> <button @click="sum++">点我++</button> <hr> <h2>姓名:{{name}}</h2> <h2>年龄:{{age}}</h2> <h2>薪资:{{job.j1.salary}}K</h2> <button @click="name+='~'">修改姓名</button> <button @click="age++">增长年龄</button> <button @click="job.j1.salary++">涨薪</button> </template> <script> import {ref,reactive,toRefs,readonly,shallowReadonly} from 'vue' export default { name: 'Demo', setup(){ //数据 let sum = ref(0) let person = reactive({ name:'张三', age:18, job:{ j1:{ salary:20 } } }) // 应用场景:比如从别的地方拿到一个数据,而且这个数据是不希望在这里被更改。 // person值就不能更改了 person = readonly(person) // 表示只有第一层是只读的,深层次的数据还是能够更改 // person = shallowReadonly(person) // sum = readonly(sum) // sum = shallowReadonly(sum) //返回一个对象(常用) return { sum, ...toRefs(person) } } } </script>
标签:shallowReadonly,name,只读,sum,person,readonly,Vue3 From: https://www.cnblogs.com/anjingdian/p/17009115.html