vue.watch什么情况触发,触发条件究竟是什么
Admin 2022-06-09 群英技术资讯 547 次浏览
很多人习惯用watch,但是却很少有人知道watch的真正触发条件。如果不是对vue原理了如指掌,请谨慎使用watch。
示例1,下面会触发watch 吗?
<script> new Vue({ data() { return { city: {id: 1, name: 'Beijing'} } }, watch: { city() { console.log('city changed') } }, created() { this.city = {id: 1, name: 'Beijing'} } }) </script>
会触发,因为在created方法里面重新给city赋值了一个对象,city前后的指向不同了
示例2:
<script> new Vue({ data() { return { city: {id: 1, name: 'Beijing'} } }, watch: { city() { console.log('city changed') } }, created() { this.city.name = 'Shanghai' } }) </script>
不会触发, 因为created方法执行之后, city的指向没有变
如果我们期望捕获这种更新,应该这样写代码:
watch: { city: { handler: () => console.log('city changed'), deep: true } }
将选项deep设为true能让vue捕获对象内部的变化。
下面讨论一下watch一个数组:
<script> new Vue({ el: '#body', data() { return { cities: ['Beijing', 'Tianjin'] } }, watch: { cities() { console.log('cities changed') } } }) </script>
那下面哪些操作会触发cities的watch回调呢?
this.cities = ['Beijing', 'Tianjin'] this.cities.push('Xiamen') this.cities = this.cities.slice(0, 1) this.cities.pop(); this.cities.sort((a,b)=>a.localeCompare(b)); this.cities[0] = 'Shenzhen' this.cities.splice(0, 1) this.cities.length = 0
答案是只有最后三行不会触发。
补充知识:vue 深度watch与watch立即触发回调
基础用法
搜索框输入搜索关键字的时候,可以自动触发搜索,此时除了监听搜索框的change事件之外,我们也可以通过watch监听搜索关键字的变化。
<template> <div> <span>搜索</span> <input v-model="searchVal" /> </div> </template> <script> export default { data() { return { searchVal: '' } }, watch: { // 在值发生变化之后,重新加载数据 searchVal(newValue, oldValue) { if (newValue !== oldValue) { this.loadData() } } }, methods: { loadData() { // 重新加载数据,此处需要通过函数防抖 } } } </script>
立即触发
通过上面的代码,现在已经可以在值发生变化的时候触发加载数据了,但是如果要在页面初始化时候加载数据,我们还需要在created或者mounted生命周期钩子里面再次调用loadData方法。不过,现在可以不用这样写了,通过配置watch的立即触发属性,就可以满足了。
export default { watch: { // 在值发生变化之后,重新加载数据 searchValue: { // 通过handler来监听属性变化, 初次调用 newValue为""空字符串, oldValue为 undefined handler(newValue, oldValue) { if (newValue !== oldValue) { this.loadData() } }, // 配置立即执行属性 immediate: true } } }
深度监听
一个表单页面,需求希望用户在修改表单的任意一项之后,表单页面就需要变更为被修改状态。如果按照上例中watch的写法,那么我们就需要去监听表单每一个属性,太麻烦了,这时候就需要用到watch的深度监听deep
export default { data() { return { formData: { name: '', sex: '', age: 0, deptId: '' } } }, watch: { // 在值发生变化之后,重新加载数据 formData: { // 需要注意,因为对象引用的原因, newValue和oldValue的值一直相等 handler(newValue, oldValue) { // 在这里标记页面编辑状态 }, // 通过指定deep属性为true, watch会监听对象里面每一个值的变化 deep: true } } }
随时监听,随时取消,了解一下$watch
有这样一个需求,有一个表单,在编辑的时候需要监听表单的变化,如果发生变化则保存按钮启用,否则保存按钮禁用。
这时候对于新增表单来说,可以直接通过watch去监听表单数据(假设是formData),如上例所述,但对于编辑表单来说,表单需要回填数据,这时候会修改formData的值,会触发watch,无法准确的判断是否启用保存按钮。现在你就需要了解一下$watch
export default { data() { return { formData: { name: '', age: 0 } } }, created() { this.$_loadData() }, methods: { // 模拟异步请求数据 $_loadData() { setTimeout(() => { // 先赋值 this.formData = { name: '子君', age: 18 } // 等表单数据回填之后,监听数据是否发生变化 const unwatch = this.$watch( 'formData', () => { console.log('数据发生了变化') }, { deep: true } ) // 模拟数据发生了变化 setTimeout(() => { this.formData.name = '张三' }, 1000) }, 1000) } } }
根据上例可以看到,我们可以在需要的时候通过this.$watch来监听数据变化。那么如何取消监听呢,上例中this.$watch返回了一个值unwatch,是一个函数,在需要取消的时候,执行 unwatch()即可取消
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:mmqy2019@163.com进行举报,并提供相关证据,查实之后,将立刻删除涉嫌侵权内容。
猜你喜欢
这篇文章主要为大家详细介绍了微信小程序实现列表项上移下移效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
JS页面访问模式是移动端或PC端方法是什么?在网站开发过程中,我们经常会遇到一些只允许计算机访问,而不允许移动访问,或者只允许移动访问,不允许PC访问的问题,因此需要判断用户的访问类型。
idea编译器出现Vue缩进报错,怎么解决呢,很多朋友遇到这个问题都很棘手,不知该如何解决,今天小编给大家通过场景分析介绍解决方案,需要的朋友参考下吧
JavaScript的Array对象是用于构造数组的全局对象,数组是类似于列表的高阶对象,下面这篇文章主要给大家介绍了关于JavaScript数组Array的一些常用方法,需要的朋友可以参考下
这篇文章主要介绍了vue项目中 jsconfig.json是什么,本文仅仅简单介绍了 jsconfig .json 的一些基本配置,而 jsconfig .json提供了大量能使我们快速便捷提高代码效率的方法,需要的朋友可以参考下
成为群英会员,开启智能安全云计算之旅
立即注册Copyright © QY Network Company Ltd. All Rights Reserved. 2003-2020 群英 版权所有
增值电信经营许可证 : B1.B2-20140078 粤ICP备09006778号 域名注册商资质 粤 D3.1-20240008