观察者

收藏785

阅读13356

更新时间2025-08-22

具有新旧值的观察者

除了新的属性值之外,以前的属性值也会自动用作观察程序方法的输入参数。

示例

我们在

元素上设置单击事件,以使用"updatePos"方法记录鼠标指针的 x 位置"xPos"。 观察者使用观察者方法的新旧输入参数来计算新的 x 位置与前一个 x 位置之间的像素差异。

{{ xDiff }}

const app = Vue.createApp({   data() {     xPos: 0,     xDiff: 0   },   watch: {     xPos(newVal,oldVal){       this.xDiff = newVal-oldVal     }   },   methods: {     updatePos(evt) {       this.xPos = evt.offsetX     }   } }) »

我们还可以使用新值和旧值在输入从无效变为有效的确切时刻向用户提供反馈:

示例

元素的值连接到观察者。 如果该值包含"@",则被视为有效的电子邮件地址。 用户会收到反馈文本,以告知输入是否有效、无效,或者上次击键后输入是否有效。

{{ feedbackText }}

const app = Vue.createApp({   data() {     inpAddress: '',     feedbackText: '',     myClass: 'invalid'   },   watch: {     inpAddress(newVal,oldVal) {       if( !newVal.includes('@') ) {         this.feedbackText = 'The e-mail address is NOT valid';         this.myClass = 'invalid';       }       else if( !oldVal.includes('@') && newVal.includes('@') ) {         this.feedbackText = 'Perfect! You fixed it!';         this.myClass = 'valid';       }       else {         this.feedbackText = 'The e-mail address is valid :)';       }     }   } }) »

观察者与方法

观察者和方法都写成函数,但有很多区别:

  • 方法从 HTML 调用。
  • 方法通常在事件发生时被调用。
  • 方法自动接收事件对象作为输入。
  • 我们还可以将我们选择的其他值发送给方法
  • 观察者仅在观察的数据属性值发生变化时才会被调用,并且这种情况会自动发生。
  • 观察者自动从被观察的属性接收新值和旧值。
  • 我们无法选择以观察者作为输入发送任何其他值.

观察者与计算属性

观察者和计算属性都被编写为函数。

当依赖项发生更改时,观察程序和计算属性都会自动调用,而不会从 HTML 中调用。

以下是计算属性和观察者之间的一些区别:

  • 观察者仅依赖于一个属性,即他们设置为监视的属性。
  • 计算属性可以依赖于许多属性。
  • 计算属性的使用方式与数据属性类似,只不过它们是动态的。
  • 观察者不是从 HTML 中引用的。

Vue 练习

通过练习测试自己

练习题:

本练习中的观察者应该在每次"rangeVal"数据属性发生变化时将"count"数据属性加一。

观察者必须被称为什么?



相关

视频

RELATED VIDEOS

更多

免费

Web前端开发极速入门
初级 Web前端开发极速入门

219920次学习

收藏

免费

前端入门_HTML5
初级 前端入门_HTML5

616946次学习

收藏

免费

30分钟学会网站布局
初级 30分钟学会网站布局

238440次学习

收藏

免费

CSS视频教程-玉女心经版
初级 CSS视频教程-玉女心经版

393054次学习

收藏

免费

独孤九贱(1)_HTML5视频教程

免费

独孤九贱(6)_jQuery视频教程

免费

独孤九贱(7)_Bootstrap视频教程

免费

独孤九贱(2)_CSS视频教程
初级 独孤九贱(2)_CSS视频教程

229605次学习

收藏

科技资讯

更多

精选课程

更多
前端入门_HTML5
前端入门_HTML5

共29课时

61.7万人学习

CSS视频教程-玉女心经版
CSS视频教程-玉女心经版

共25课时

39.3万人学习

JavaScript极速入门_玉女心经系列
JavaScript极速入门_玉女心经系列

共43课时

70.9万人学习

独孤九贱(1)_HTML5视频教程
独孤九贱(1)_HTML5视频教程

共25课时

61.6万人学习

独孤九贱(2)_CSS视频教程
独孤九贱(2)_CSS视频教程

共22课时

23万人学习

独孤九贱(3)_JavaScript视频教程
独孤九贱(3)_JavaScript视频教程

共28课时

33.9万人学习

独孤九贱(4)_PHP视频教程
独孤九贱(4)_PHP视频教程

共89课时

125万人学习

关于我们 免责申明 意见反馈 讲师合作 广告合作 最新更新 English
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送
PHP中文网APP
随时随地碎片化学习

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号