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

组合式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)
})

相关文章:

  • 北京网站建设多少钱?
  • 辽宁网页制作哪家好_网站建设
  • 高端品牌网站建设_汉中网站制作
  • Linux和Unix的区别及为什么鸿蒙系统不用Unix的原因
  • 排序算法(冒泡、插入、选择、快排、归并)原理动画及Python、Java实现
  • 进程、线程的区别
  • identYwaf:一款基于盲推理识别技术的WAF检测工具
  • LLM - GPT(Decoder Only) 类模型的 KV Cache 公式与原理 教程
  • 解决:pip install flash-attn安装失败案例【cuda】【torch】【flash-attn】
  • mysql 不同版本安装不同端口
  • 企业级Mysql 集群技术部署
  • 55.基于IIC协议的EEPROM驱动控制(2)
  • 使用Spring Cloud Consul进行分布式配置的深度解析与实战
  • 【中学教资-信息技术】多媒体文件大小的存储
  • 【计组 | Cache原理】讲透Cache的所有概念与题型方法
  • BMC lighttpd kvm数据分析(websocket)
  • 如何接收请求数据
  • 旅行追踪和行程规划工具AdventureLog
  • IE9 : DOM Exception: INVALID_CHARACTER_ERR (5)
  • 自己简单写的 事件订阅机制
  • 10个确保微服务与容器安全的最佳实践
  • laravel 用artisan创建自己的模板
  • Next.js之基础概念(二)
  • python3 使用 asyncio 代替线程
  • React-flux杂记
  • Tornado学习笔记(1)
  • vuex 笔记整理
  • 对象引论
  • 基于阿里云移动推送的移动应用推送模式最佳实践
  • 聊一聊前端的监控
  • Java性能优化之JVM GC(垃圾回收机制)
  • ​DB-Engines 11月数据库排名:PostgreSQL坐稳同期涨幅榜冠军宝座
  • ​Redis 实现计数器和限速器的
  • #QT(串口助手-界面)
  • %3cli%3e连接html页面,html+canvas实现屏幕截取
  • (14)Hive调优——合并小文件
  • (4)Elastix图像配准:3D图像
  • (Bean工厂的后处理器入门)学习Spring的第七天
  • (C++)栈的链式存储结构(出栈、入栈、判空、遍历、销毁)(数据结构与算法)
  • (Qt) 默认QtWidget应用包含什么?
  • (二)十分简易快速 自己训练样本 opencv级联lbp分类器 车牌识别
  • (附源码)springboot家庭财务分析系统 毕业设计641323
  • (附源码)ssm码农论坛 毕业设计 231126
  • (含react-draggable库以及相关BUG如何解决)固定在左上方某盒子内(如按钮)添加可拖动功能,使用react hook语法实现
  • (企业 / 公司项目)前端使用pingyin-pro将汉字转成拼音
  • (四)TensorRT | 基于 GPU 端的 Python 推理
  • (转)真正的中国天气api接口xml,json(求加精) ...
  • ***汇编语言 实验16 编写包含多个功能子程序的中断例程
  • .gitignore文件---让git自动忽略指定文件
  • .NET Core 版本不支持的问题
  • .Net Remoting(分离服务程序实现) - Part.3
  • .NET周刊【7月第4期 2024-07-28】
  • :O)修改linux硬件时间
  • @transaction 提交事务_【读源码】剖析TCCTransaction事务提交实现细节
  • [ 手记 ] 关于tomcat开机启动设置问题
  • [2010-8-30]
  • [2018][note]用于超快偏振开关和动态光束分裂的all-optical有源THz超表——
  • [Android]RecyclerView添加HeaderView出现宽度问题