vue3: ref, reactive, readonly, shallowReactive

vue3: ref, reactive, readonly, shallowReactive

原文地址:https://mp.weixin.qq.com/s/S3jPZKEMBP8nQQObF5d2VA

javascript 复制代码
<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>
相关推荐
吃杠碰小鸡5 分钟前
高中数学-数列-导数证明
前端·数学·算法
kingwebo'sZone11 分钟前
C#使用Aspose.Words把 word转成图片
前端·c#·word
xjt_090130 分钟前
基于 Vue 3 构建企业级 Web Components 组件库
前端·javascript·vue.js
我是伪码农42 分钟前
Vue 2.3
前端·javascript·vue.js
夜郎king1 小时前
HTML5 SVG 实现日出日落动画与实时天气可视化
前端·html5·svg 日出日落
辰风沐阳1 小时前
JavaScript 的宏任务和微任务
javascript
夏幻灵2 小时前
HTML5里最常用的十大标签
前端·html·html5
冰暮流星2 小时前
javascript之二重循环练习
开发语言·javascript·数据库
Mr Xu_2 小时前
Vue 3 中 watch 的使用详解:监听响应式数据变化的利器
前端·javascript·vue.js
未来龙皇小蓝2 小时前
RBAC前端架构-01:项目初始化
前端·架构