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 小时前
XSS(跨站脚本攻击)
前端·网络·xss
天天进步20155 小时前
前端安全指南:防御XSS与CSRF攻击
前端·安全·xss
呼啦啦呼啦啦啦啦啦啦6 小时前
利用pdfjs实现的pdf预览简单demo(包含翻页功能)
android·javascript·pdf
拾光拾趣录7 小时前
括号生成算法
前端·算法
拾光拾趣录8 小时前
requestIdleCallback:让你的网页如丝般顺滑
前端·性能优化
前端 贾公子8 小时前
vue-cli 模式下安装 uni-ui
前端·javascript·windows
拾光拾趣录8 小时前
链表合并:双指针与递归
前端·javascript·算法
@大迁世界8 小时前
前端:优秀架构的坟墓
前端·架构
拼图2098 小时前
element-plus——图标推荐
javascript·vue.js·elementui
期待のcode8 小时前
图片上传实现
java·前端·javascript·数据库·servlet·交互