组合式API-reactive和ref函数,computed计算属性,watch函数

一.reactive()接收一个对象类型的数据,返回一个响应式的对象:

<script setup>
import {reactive} from 'vue'
const state = reactive({count:100
})
const setCount =() => {state.count++
}
</script>
<template><div><div>{{ state.count }}</div><button @click="setCount">+1</button></div>
</template>

 二.ref()接收简单类型或者对象类型的数据传入并返回一个响应式对象

推荐声明数据,统一用ref

注意:脚本中访问数据,需要通过.value

          在template中,.value不需要加(自动扒掉了一层)

<script setup>
import {ref} from 'vue'
const count = ref (0)
const setCount = () => {count.value ++
}
</script>
<template><div>{{ count }}</div><button @click="setCount">+1</button>
</template>

三.computed计算属性

const 计算属性 = computed (() => {
   return 计算返回的结果

}

<script setup>
import {computed,ref} from 'vue'
const list = ref([1,2,3,4,5,6,7,8
])
const computedList = computed(() => {return list.value.filter(item => item > 2)
})
</script><template><div><div>原始数据:{{ list }}</div><div>计算后数据:{{ computedList }}</div></div>
</template>

增加一个修改函数

<script setup>
import {computed,ref} from 'vue'
const list = ref([1,2,3,4,5,6,7,8
])
const computedList = computed(() => {return list.value.filter(item => item > 2)
})const addFn = () =>{
list.value.push(666)
}
</script><template><div><div>原始数据:{{ list }}</div><div>计算后数据:{{ computedList }}</div></div><button @click="addFn">修改添加</button>
</template>

注意:计算属性不应该有“副作用”,比如异步请求/修改dom

           避免直接修改计算属性的值,计算属性应该是只读的,特殊情况可以配置get  set 


四.watch函数

作用:侦听一个或者多个数据的变化,数据变化时执行回调函数

俩个额外参数:1.immediate(立即执行) 2.deep(深度侦听)

1,侦听单个数据

  • 导入watch函数
  • 执行watch函数传入要侦听的响应式数据(ref对象)和回调函数

watch(ref对象,(newValue,oldValue) => {...} )

<script setup>
import {ref,watch} from 'vue'
const count = ref(0)
const nickname = ref('张三')
const changeCount = () =>{count.value++
}
const changeNickname = () =>{nickname.value = '李四'
}
//1.监视单个数据变化
// watch(ref对象,(newValue,oldValue) => {...})
watch(count,(newValue,oldValue) => {console.log(newValue,oldValue)
})<template><div>{{ count }}</div><button @lick="changeCount">改数字</button><div>{{ nickname }}</div><button @click="changeNickname">改昵称</button>
</template>

2,侦听多个数据

watch( [ref对象1,ref对象2],(newArr,oldArr) => {...} )

<script setup>
import {ref,watch} from 'vue'
const count = ref(0)
const nickname = ref('张三')
const changeCount = () =>{count.value++
}
const changeNickname = () =>{nickname.value = '李四'
}
</script>
<template><div>{{ count }}</div><button @lick="changeCount">改数字</button><div>{{ nickname }}</div><button @click="changeNickname">改昵称</button>
</template>

3.配置额外的项

原本的监听只在修改内容时触发一次,如果希望一进页面就触发一次,在第三个参数位置放上一个对象,对象里放上immediate:true

<script setup>
const countt = ref(0)
const setcountt = () =>{countt++
}
watch(countt,(newValue,oldValue) =>{console.log('countt发生了变化')
},{immediate:true,// deep:true
})
</script>
<template><button @click="setcountt">修改countt的值</button>
</template>

 

4.深度监视

 deep进行深度监视,而watch默认进行的是浅层监视

const ref1 = ref(简单类型) 可以直接监视

const ref2 = ref(复杂类型) 监视不到复杂类型内部数据变化

 

<script setup>
const userInfo = ref({name:'zs',age:18
})
const setusreInfo = () => {userInfo.value.age++   //地址改变的是对象里的属性,整个对象地址是没有改变的
}
watch(userInfo,(newValue) =>{    //仅仅如此检测到的数据是没有变化的,因为传入的是userInfo对象,而该对象地址并没有改变,改变的是对象里的属性,也就是要进行深层监视,所以在下面再添加一个对象写上deep属性console.log(newValue)
},{deep:true
})</script><template><button>修改userInfo</button>
</template>

5.对于对象中的属性进行监视

watch(() =>userInfo.value.age,(newValue,oldValue) => {console.log(newValue,oldValue)
})

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/878238.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

书生大模型实战营第三期进阶岛第三课——LMDeploy 量化部署实践

LMDeploy 量化部署实践 任务一&#xff1a;创建虚拟环境创建文件夹LMDEPLOY用于存放课程相关的文件创建模型软连接LMDeploy验证启动模型文件LMDeploy API部署InternLM2.5-1.8b以命令行形式连接API服务器以Gradio网页形式连接API服务器LMDeploy KV量化W4A16 模型量化和部署W4A16…

学习日志28

论文阅读&#xff1a;Quantum speed-ups in reinforcement learning 量子强化学习&#xff08;Quantum Reinforcement Learning, QRL&#xff09;是一种结合了量子计算和强化学习的方法&#xff0c;旨在利用量子力学的原理来加速和优化智能体的学习过程。量子加速则是指利用量子…

valgrind安装及使用

安装 下载源码下载地址 tar -jxvf valgrind-3.23.0.tar.bz2 cd valgrind-3.23.0 ./autogen.sh ./configure --prefix安装目录 make make install使用文档 官方文档

create-react-app 移除 ESLint 语法检查

ESLint 的作用&#xff1a; ESLint 是一个流行的 JavaScript 代码静态检查工具&#xff0c;旨在帮助开发者识别和修复代码中的问题。以下是关于 ESLint 的一些关键信息&#xff1a; 主要功能&#xff1a; 1.代码风格检查&#xff1a;ESLint 可以检查代码是否符合特定的编码风…

mysql 数据区备份

第一步 &#xff0c;进入mysql窗口锁住数据库&#xff08;不锁的可以只执行第二步&#xff09;&#xff1a; use dbName-- 使用xx数据库flush tables with read lock; -- 锁住数据库。第二步&#xff1a;打开cmd窗口&#xff0c;或者liunx命令行窗口 C:\Users\User>mysqld…

经典算法之链表篇(二)

目录 一&#xff1a;重排链表&#xff08;LeetCode.143&#xff09; 二&#xff1a;删除链表的节点&#xff08;LCR 136. 删除链表的节点&#xff09; 三&#xff1a;K个一组反转链表&#xff08;LeetCode.25&#xff09; 有关经典算法链表的第一篇内容&#xff0c;可以查看我…

ESXi服务器无法安装Windows11:“不符合此版本的Windows所需最低系统要求“

目录 一、问题描述1.使用环境2.问题截图3.问题解析 二、解决方法Ⅰ1.按 ShiftF10 弹出命令提示符2.在弹出的Dos框中输入regedit&#xff0c;回车&#xff0c;进入注册表。3.打开HKEY_LOCAL_MACHINE\SYSTEM\Setup&#xff0c;并新建 LabConfig 的项&#xff0c;在 LabConfig 下创…

使用预训练的 ONNX 格式的 YOLOv8n 模型进行目标检测,并在图像上绘制检测结果

目录 __init__方法&#xff1a; pre_process方法&#xff1a; run方法&#xff1a; filter_boxes方法&#xff1a; view_img方法&#xff1a; __init__方法&#xff1a; 初始化类的实例时&#xff0c;创建一个onnxruntime的推理会话&#xff0c;加载名为yolov8n.onnx的模型…

C#开发基础之100个常用的C#正则表达式

前言 正则表达式是处理字符串的强大工具&#xff0c;特别是在文本搜索、替换和验证中。本文将100个常用的C#正则表达式进行分类&#xff0c;以帮助我们更快速地找到适合的正则表达式解决方案。 1. 基础匹配 这些正则表达式用于匹配一些基本的字符或字符串模式。 匹配任意字…

利用 Pytest Cache Fixture 实现中间数据缓存

接口自动化过程中&#xff0c;经常会遇到这样一些场景&#xff0c;“请求2需要用到请求1响应的数据”&#xff0c;常见的做法&#xff0c;进行用例依赖或者将请求1的响应结果写入一个文件&#xff0c;用到的时候读取文件。 当然这都不是这篇文章的重点&#xff0c;本片文章主要…

macos MacPort 包管理工具安装和使用

在macos v10.15版本中, xz, python等软件无法使用brew安装, 原因是brew对于旧版本的macos不再支持, 但是我们可以使用另外一个macos下的包管理工具来安装brew无法安装的软件, macport 是一个和brew类似的macos下的一个非常优秀的软件包安装管理工具. MacPort安装前提条件 安…

AR.js 开发与使用指南

1. AR.js 简介 AR.js 是基于 Web 技术的 AR 库&#xff0c;依赖于 WebGL 和 WebRTC&#xff0c;可以在大多数现代浏览器上运行。它的主要优势在于不需要安装任何插件或应用程序&#xff0c;用户只需通过浏览器即可体验 AR 效果。AR.js 提供了 Marker-based&#xff08;基于标记…

假期学习--对象底层结构和继承链

OC本质底层实现转化其实都是C/C代码。 OC对象的本质就是结构体。 NSObject底层是struct objc_object结构体 &#xff1b;struct objc_class : objc_object { …省略无关代码 // Class ISA; //ISA(从objc_object继承过来的) Class superclass; //指向其父类 cache_t cache…

【Istio】

Istio 是一个开源的服务网格&#xff08;Service Mesh&#xff09;平台&#xff0c;设计用于帮助开发者和运维人员管理、保护和监控微服务架构。随着微服务架构的广泛采用&#xff0c;服务间通信的管理变得越来越复杂。Istio 通过在服务之间插入一个透明的网络层&#xff0c;简…

旅游行业怎么利用C#接口发送短信

旅游企业一般拥有众多的分支机构&#xff0c;同时各地分支机构又有众多下属分散在当地各区的旅游营业报名点&#xff0c;以前传统的解决方案是采用专线、MODEM拔号等方式&#xff0c;专线的成本很高&#xff0c;MODEM拔号更费时&#xff0c;且长途拔号互联成本在多点情况下费用…

企业数据治理之主数据---供应商主数据

一、供应商主数据的定义 供应商是向企业或个人提供商品、服务或资源的个人、公司或其他实体。一般企业内部的供应商有多种&#xff0c;有零部件采购供应商、材料采购供应商、设备采购供应商、外协生产供应商等&#xff0c;而且这些供应商在企业内部有可能有不同的部门负责&…

微前端集成优化:让所有子应用体积更小,加载更快!

简介 随着前端的日益发展&#xff0c;微前端架构越来越受到青睐。它通过将前端应用拆分为多个独立的子应用&#xff0c;每个子应用可以独立开发、部署和运行&#xff0c;从而提升了开发效率和团队协作。目前主流的微前端方案应该是qiankun了。 以笔者公司为例&#xff0c;采用…

基于SpringBoot的在线答疑系统

你好呀&#xff0c;我是计算机专业毕业生&#xff0c;专注于在线教育平台的开发与实现。 开发语言&#xff1a;Java 数据库&#xff1a;MySQL 技术&#xff1a;Java技术 Spring Boot框架 工具&#xff1a;IntelliJ IDEA、Navicat、Maven、Tomcat 系统展示 首页 个人中心…

【C#】【EXCEL】Bumblebee/Components/Analysis/GH_Ex_Ana_CondAverage.cs

Bumblebee/Components/Analysis/GH_Ex_Ana_CondAverage.cs 这段代码定义了一个名为 GH_Ex_Ana_CondAverage 的类&#xff0c;它是一个 Grasshopper 组件。这个组件的主要功能是为 Excel 工作表中的一个范围添加基于平均值的’条件格式’。以下是对这个组件的功能和特点的详细介…

FFmpeg源码:read_packet_wrapper、fill_buffer函数分析

AVIOContext结构体和其相关的函数分析&#xff1a; FFmpeg源码&#xff1a;avio_r8、avio_rl16、avio_rl24、avio_rl32、avio_rl64函数分析 FFmpeg源码&#xff1a;read_packet_wrapper、fill_buffer函数分析 FFmpeg源码&#xff1a;avio_read函数分析 FFmpeg源码&#xff…