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>
相关推荐
Fantasywt3 小时前
THREEJS 片元着色器实现更自然的呼吸灯效果
前端·javascript·着色器
IT、木易4 小时前
大白话JavaScript实现一个函数,将字符串中的每个单词首字母大写。
开发语言·前端·javascript·ecmascript
Mr.NickJJ5 小时前
JavaScript系列06-深入理解 JavaScript 事件系统:从原生事件到 React 合成事件
开发语言·javascript·react.js
张拭心6 小时前
2024 总结,我的停滞与觉醒
android·前端
念九_ysl6 小时前
深入解析Vue3单文件组件:原理、场景与实战
前端·javascript·vue.js
Jenna的海糖6 小时前
vue3如何配置环境和打包
前端·javascript·vue.js
Mr.NickJJ6 小时前
React Native v0.78 更新
javascript·react native·react.js
星之卡比*6 小时前
前端知识点---库和包的概念
前端·harmonyos·鸿蒙
灵感__idea6 小时前
Vuejs技术内幕:数据响应式之3.x版
前端·vue.js·源码阅读
烛阴7 小时前
JavaScript 构造器进阶:掌握 “new” 的底层原理,写出更优雅的代码!
前端·javascript