vue3: ref, reactive, readonly, shallowReactive

news/2024/11/16 16:29:33 标签: 前端, javascript, vue3.js

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>

http://www.niftyadmin.cn/n/5754387.html

相关文章

数据结构概述及线性结构

1.数据结构研究的两个东西&#xff1a;逻辑结构和存储结构 2.逻辑结构&#xff1a; 线性&#xff1a;1&#xff1a;1,表。例如每个学生都有唯一的学号。顺序表&#xff0c;链式表。非线性&#xff1a;层级关系&#xff08;1&#xff1a;n&#xff09;&#xff0c;树。例如电脑…

Opengl光照测试

代码 #include "Model.h" #include "shader_m.h" #include "imgui.h" #include "imgui_impl_glfw.h" #include "imgui_impl_opengl3.h" //以上是放在同目录的头文件#include <glad/glad.h> #include <GLFW/glfw3.…

PySpark3:Row对象常见操作以及Row、RDD、DataFrame互相转换

目录 一、Row对象常见操作 二、Row、RDD、DataFrame互相转换 1、RDD—>DataFrame 2、DataFrame—>RDD 3、DataFrame—>Row 4、Row—>DataFrame 一、Row对象常见操作 from pyspark.sql import Row# 创建一个Row对象 row Row(name"张三", age25)# …

.NET 9 - BinaryFormatter移除

1.简单介绍 .NET 9 SDK正式版已经发布, 下载地址是.NET9 同时.NET Conf 2024 大会已经从2024-11-13开始了&#xff0c;感觉Aspire和AI的内容相对挺多的&#xff0c;主题分享演示时候打开的网站大部分都是Blazor制作的。 这次.NET Conf 2024老师也再次说明了一下&#xff0c;…

1 图的搜索 奇偶剪枝

图论——图的搜索_Alex_McAvoy的博客-CSDN博客 语雀版本 1 深度优先搜索DFS 1. 从图中某个顶点 v0 出发&#xff0c;首先访问 v0 2. 访问结点 v0 的第一个邻接点&#xff0c;以这个邻接点 vt 作为一个新节点&#xff0c;访问 vt 所有邻接点&#xff0c;直到以 vt 出发的所有节…

回顾二维数组——数组指针部分

数组指针才真正等同于二维数组名 数组指针&#xff1a; 当运行下面的代码的时候&#xff0c;会有警告&#xff0c;偏移量不同&#xff0c;arr偏移的是整行数组&#xff0c;与注释的p不同&#xff0c;如果p&arr[0][0],p表示的就是依次、连续的12个元素地址&#xff0c;偏移…

sql专场练习(二)(1-5)

第一题 create database yhdb01; show tables ; create table sql2_1(uid int,subject_id int,score int ) row format delimited fields terminated by "\t"; load data local inpath /home/homedata/sql2/sql2_1.txt into table sql2_1; select * from sql2_1;100…

Vue.js 前端框架入门

简介 Vue.js 是一个构建用户界面的渐进式JavaScript框架。本文将带你了解Vue项目的目录结构&#xff0c;启动顺序&#xff0c;并逐步指导你安装必要的环境&#xff0c;以及如何开发一个基础的Vue项目。 需要的环境 Node.js&#xff1a;Vue.js 项目依赖于Node.js&#xff0c;…