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

vue3: ref, reactive, readonly, shallowReactive

vue3: ref, reactive, readonly, shallowReactive

原文地址:https://mp.weixin.qq.com/s/S3jPZKEMBP8nQQObF5d2VA
在这里插入图片描述

<template><!-- <ul><li v-for="item in list.arr">{{item}}</li></ul><button @click.prevent="add">添加</button> --><!-- <button @click.prevent="show">查看</button> --><div>{{ obj2 }}</div><button @click.prevent="edit">修改</button></template>
<script setup lang='ts'>
import { ref, reactive, readonly, shallowReactive } from 'vue';
/*
ref:支持所有类型;取值/赋值都需加.value,reactive不需要。
reactive:支持引用类型 Array Object Map Set;由proxy代理,不能直接赋值,否则会破坏响应式对象; 
解决方案:可以使用数组push加解构;或者添加一个对象,把数组作为一个属性去解决 ;
readonly:属性不可修改。会受到原始对象的影响,原始对象改变readonly声明的属性也会改变 
shallowReactive:声明的数据浅层次响应式数据,数据改变视图不会更新;修改对象最顶层属性,
数据改变视图会发生更新。reactive,shallowReactive 两者不可同时使用写在一起,否则ref影响成shallowRef视图更新;
影响原因:ref 底层会调用 triggerRef; triggerRef会强制更新收集的依赖。
*/
let obj=reactive({name:"小满"});
const obj2:any=shallowReactive({foo:{bar:{num:1}}
});
const edit= ()=> {// 浅层次响应式数据,数据改变视图不会更新// obj2.foo.bar.num=456// 浅层次响应式数据,修改对象最顶层属性foo,数据改变视图会发生更新obj2.foo={name:"小田"}console.log(obj2);}// let obj=reactive({name:"小田"});
// // 属性不可修改
// const read=readonly(obj);
// const show = () => {
//   obj.name="大田"
//   console.log("obj:",obj);
//   console.log("read:",read);
// }// let list=reactive<String[]>([]);
let list=reactive<{arr:String[]
}>({arr:[]
});
const add = () => {setTimeout(()=>{let res=["EDG","RNG","JDG"]// //方案1: 使用数组push加解构// list.push(...res);// 方案2:添加一个对象,把数组作为一个属性去解决list.arr=res;},500);console.log(list);}
</script>
<style scoped></style>

http://www.mrgr.cn/news/76375.html

相关文章:

  • 机器人碳钢去毛刺,用大扭去毛刺主轴可轻松去除
  • [SMARTFORMS] 导出SMARTFORMS表单数据
  • MySQL 16 章——变量、流程控制和游标
  • 关于扫描模型 拓扑 和 传递贴图工作流笔记
  • python项目结构,PyCharm 调试Debug模式配置
  • 解决anaconda prompt找不到的情况
  • uniapp: 微信小程序包体积超过2M的优化方法
  • Vue和Vue-Element-Admin(十三):基于vue2比较学习vue3
  • 【AIGC】如何通过ChatGPT提示词Prompt定制个性学习计划
  • vue3: toRef, reactive, toRefs, toRaw
  • linux下编译安装memcached
  • Android ART知多少?
  • 《抽象类和接口》
  • 渗透测试之信息收集 DNS主机发现探测方式NetBIOS 协议发现主机 以及相关PorCheck scanline工具的使用哟
  • 跳房子(弱化版)
  • 芯原科技嵌入式面试题及参考答案
  • cMake编译github中源码
  • flink cdc 应用
  • 重建大师跑空三,出现进度条回退是什么原因?
  • 城市轨道交通数据可视化的应用与优势
  • Intelligent Transportation Scheduling
  • IT框架与库:理解它们的不同与共同点
  • 用友YonBIP-R5旗舰版 yonbiplogin 任意文件读取漏洞复现
  • Rust 语言学习笔记(一)
  • uniapp luch-request 使用教程+响应对象创建
  • C++ 20的条件判断语句的增强