【VUE复习·6】监视属性watch:用途、两种写法、简写、应用时注意事项(重点)、深度监视(重点)

总览

1.监视属性是用来干什么的?

2.监视属性的两种写法

3.应用时注意事项

4.深度监视

一、监视属性是用来干什么的?

1.用途

监视一个值(可以是基本属性 data,或者是计算属性 computed)是否被改变。如果此值被改变,那么则触发一个事件。

比如说,在下图示例代码中,我们监视了 基本属性isHot ,如果 isHot 的值发生了改变,那么我们就会执行 handler 函数(完整写法中),且我们能够拿到改变前的值(oldValue)和 改变后的值(newValue)。

二、监视属性的两种写法

1.方法1

如上图(或下图都一样)。

简写时,我们不需要写 handler 函数,直接在被监视对象中写即可。

2.方法2

如下图:

请注意,下图中,也就是方法2中,这种监视方式必须将 .$watch 挂在 VUE 实例后面,要写在 VUE 实例对象之外,而不能和 data、computed、methods 等一样,写在 VUE 实例之内。

三、应用时注意事项

1. 多级结构的写法

因为最原生的写法中,应该是 VUE实例.$watch('监视对象',{ handler(){xxx} })

请注意,监视对象是需要被 ' ' 括起来的。我们刚才直接写的 watch:{ isHot:{} } 其实是简写,完整的应该是:watch:{ 'isHot':{} } 。

所以,在对有多级结构的数据进行监视的时候,我们需要给监视的(watch内的)对象加上 ' '。如图所示:

四、深度监视

1.错误示例

我们想要监测一个结构中所有值的变化。

比如 numbers.a 和 numbers.b 只要其中一个变化了,那么就触发了 "numbers改变了" 这个 console.log。

如果我们像下面这样写,其实是无效的。因为下面的写法监视的不是 numbers 中 a、b 的变化,而是整个 numbers 中内容的地址值的变化。这是不行的。

2.正确示例

正确写法是,我们需要加上一个属性标签 deep:true。告诉 VUE 我们要对 numbers 这个结构内的所有键值进行监视,谁变了都会触发 "numbers改变了" 这个 console.log。

相关推荐
sww_10263 小时前
智能问数系统(二):数据分析师Python
java·前端·python
爱上妖精的尾巴3 小时前
7-13 WPS JS宏 this 用构造函数自定义类-2,调用内部对象必须用this
开发语言·javascript·wps·jsa
一 乐3 小时前
学生宿舍管理|基于springboot + vue学生宿舍管理系统(源码+数据库+文档)
java·数据库·vue.js·spring boot·后端·助农电商系统
一人の梅雨3 小时前
义乌购商品详情接口进阶实战:批发场景下的精准解析与高可用架构
java·服务器·前端
bin91533 小时前
(文后附完整代码)html+css+javascript 弓箭射击游戏项目分析
前端·javascript·css·游戏·html·前端开发
翱翔的苍鹰4 小时前
完整的“RNN + jieba 中文情感分析”项目的Gradio Web 演示的简单项目
前端·人工智能·rnn
有味道的男人4 小时前
如何使用招标网API获取项目详情?
java·服务器·前端
qq_406176144 小时前
深入剖析JS中的XSS与CSRF漏洞:原理、攻击与防御全指南
服务器·开发语言·前端·javascript
RFCEO4 小时前
HTML编程 课程六、:HTML5 新增多媒体标签
前端·html·html5·多媒体标签·嵌入音频、视频、动画
yanyu-yaya4 小时前
速学兼复习之vue3章节4
前端·vue.js·前端框架