当前位置: 首页 > article >正文

vue3 计算属性(computed)和监听属性(watch)的异同

计算属性(computed)

//使用计算属性 {{fullName}}
//使用方法 {{fullName() }}

const firstName=ref("杰克")
const lastName=ref("麻子")
//计算属性
const fullName=computed(()=>firstName.value+"-"+lastName.value)
//方法
const fullName=()=>firstName.value+"-"+lastName.value

计算属性和方法比较?
相同:结果完全相同。
不同:计算属性值会基于其响应式依赖被缓存,一个计算属性仅会在其响应式依赖更新时才会重新计算。 方法调用总是会在重渲染发生时再次执行函数。比较消耗性能。

//计算属性只读,使用 fullName.value,其数据源可以修改(firstName,lastName)

监听属性(watch)

//一--------监听字符串
let person=ref("")
watch(person,(newvalue,oldvalue)=>{})

//二------监听对象 
let person=ref({
		name:"张三",
		age:18
	})
/* watch(person,(newvalue,oldvalue)=>{
     console.log(newvalue,oldvalue) //当改变v-model的person.name值时,此时拿不到值,因为watch是一个浅层监听,需要深度监听。
}) **/
//开启深度监听
//① 监听某个特定的值,name
watch(()=>person.value.name,(newvalue,oldvalue)=>{})
//② 监听不确定哪一个值
watch(person,(newvalue,oldvalue)=>{},{deep:true},{immediate:true})
//immediate:true开启立即执行,立马拿到原数据

//三-------watchEffect 自动监听哪些数据发送改变
watchEffect(()=>{
	console.log(newvalue,oldvalue) //(只要数据源发生改变就会打印)
	})

区别

  • 计算属性函数必须有return函数,监听属性不必须。
  • .计算属性不能执行异步操作,watch允许在发生改变时执行异步操作或复杂的逻辑。
  • 计算属性是基于它们的依赖进行缓存的,只有依赖发生变化才会重新计算,watch没有缓存,数据发生改变 直接触发对应的事件。
  • computed可以自定义名称,而watch只能监听 props和data里面名称相同的属性。

计算属性适用于派生出新的数据,而监听属性适用于在数据变化时执行异步操作或复杂逻辑。


http://www.kler.cn/a/273635.html

相关文章:

  • 【GESP】C++二级练习 luogu-B2079, 求出 e 的值
  • scrapy爬取图片
  • 《解锁图像的语言密码:Image Caption 开源神经网络项目全解析》
  • 如何在 Linux系统用中挂载和管理磁盘分区
  • Kivy,跨平台UI的艺术家
  • 【C++/控制台】2048小游戏
  • 租一个阿里云的服务器多少钱?30元、61元、99元、165元、199元
  • 机器学习复习(9)——自定义dataset
  • Linux 文件系统:文件描述符、管理文件
  • vue3.x 使用jsplumb进行多列拖拽连线
  • C++ cin标准输入流,及获取多个输入的方法
  • Springboot整合支付宝沙箱支付
  • 移动云COCA架构实现算力跃升,探索人工智能新未来
  • 【C语言】空心正方形图案
  • 【开发】SpringBoot 整合 Redis
  • 自然辩证法
  • bootstrap表格API文档
  • 【Linux】用三种广义进程状态 来理解Linux的进程状态(12)
  • GPT-SoVITS语音合成服务器部署,可远程访问(全部代码和详细部署步骤)
  • 海康、新华三、银江股份、大华等知名企业集结亮相“杭州安防展”
  • 杂记8---多线激光雷达与相机外参标定
  • java项目打包(maven+原生)
  • LeetCode108 将有序数组转换为二叉搜索树
  • 云原生(四)、Docker-Compose
  • js复制内容到剪贴板实现复制粘贴功能
  • git tag标签使用