vue中 computed和watch的一些简单理解(区别)
今天看到一个问题,就是vue的computed和watch要在哪些场景下使用,其实也就是在问他们的区别。computed也就是计算属性,它可以帮助我们将在模板中的一些稍微复杂的逻辑计算放回到js代码中,方便理解与修改维护;就拿官网给的例子,如下代码片段。
<div id="example"> {{ message.split('').reverse().join('') + number }} </div>
这js片段虽然看起来挺简单的,但是,如果以后多了需求,要做多一两步的逻辑,在模板里面维护起来就麻烦了,所以类似这种的,我们将其写到computed计算属性里面。也就是下面这样子,这样子看起来美观,一看就清楚这是干啥用的
<template> <div> <p>{{ reversedMessage }}</p> </div> </template> <script> export default { name: 'test1', data () { return { message: 'hello world', number: 1 } }, computed: { // 字符串反转 reversedMessage () { return this.message.split('').reverse().join('') + this.number } } } </script>
在computed中定义的每一个计算属性,都会被缓存起来,只有当计算属性里面依赖的一个或多个属性变化了,才会重新计算当前计算属性的值。上面的代码片段中,在reversedMessage中,它依赖了message和number这两个属性,一旦其中一个变化了,reversedMessage会立刻重新计算输出新值。
watch是属性监听器,一般用来监听属性的变化(也可以用来监听计算属性函数),并做一些逻辑。在这里就稍微说下他监听属性的功能吧。
<template> <div> <p>{{ this.number }}</p> </div> </template> <script> export default { name: 'test1', data () { return { number: 1 } }, created () { setTimeout(() => { this.number = 100 }, 2000) }, watch: { number (newVal, oldVal) { console.log('number has changed: ', newVal) } } } </script>
上面的代码中,我们在watch中监听了number属性,并且在实例创建后2s执行对number属性的值的更改。我们可以在控制台中看到2s后打印了如下图:
就我自己目前来说,watch一般就用来一个数据来影响多个数据的操作,或者比如说是用来监听input然后进行一些即时搜索操作什么的。
大概总结一下,computed和watch的使用场景并不一样,computed的话是通过几个数据的变化,来影响一个数据,而watch,则是可以一个数据的变化,去影响多个数据。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列:基于图像分类模型对图像进行分类
· go语言实现终端里的倒计时
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 25岁的心里话
· 闲置电脑爆改个人服务器(超详细) #公网映射 #Vmware虚拟网络编辑器
· 基于 Docker 搭建 FRP 内网穿透开源项目(很简单哒)
· 零经验选手,Compose 一天开发一款小游戏!
· 一起来玩mcp_server_sqlite,让AI帮你做增删改查!!