watch深度监听newValue === oldValue
时间: 2023-08-13 11:04:34 浏览: 161
您的问题是关于在Vue.js中如何使用watch来进行深度监听newValue是否等于oldValue的问题。如果您想要在Vue.js中使用watch来进行深度监听,请使用`deep`选项来设置深度监听,并在监听函数中使用`Object.is`方法来判断`newValue`是否等于`oldValue`,如下所示:
```javascript
watch: {
value: {
deep: true,
handler(newValue, oldValue) {
if (Object.is(newValue, oldValue)) {
// newValue 等于 oldValue
} else {
// newValue 不等于 oldValue
}
}
}
}
```
这样,当`value`的值发生变化时,Vue.js将会递归地比较`newValue`和`oldValue`的所有属性,直到找到不同的属性为止。如果`newValue`等于`oldValue`,则执行`if`语句中的代码,否则执行`else`语句中的代码。
相关问题
watch: { scrollTop: { handler: function (newValue, oldValue) { clearTimeout(this.timer); this.timer = setTimeout(() => { if (newValue == window.scrollY) { this.oldScrollTop = newValue; if (this.oldScrollTop > 100) { this.show = true; } else { this.show = false; } } else { if (this.oldScrollTop == oldValue) { // console.log("滚动开始"); } } }, 20); }, immediate: true, }, },什么意思
这是一个Vue.js的`watch`选项,用于监听组件中的`scrollTop`数据变化,并在变化时执行相应的操作。
具体来说,`watch`选项可以监听组件中任意一个数据的变化,并在数据变化时执行特定的逻辑,类似于Vue.js中的计算属性,但是具有更高的灵活性和自定义性。
在这段代码中,`watch`选项监听了组件中的`scrollTop`数据变化,每当`scrollTop`发生变化时,会执行一个回调函数`handler`。该回调函数会先清除之前设置的定时器`timer`,然后重新设置一个定时器,延迟20毫秒执行。如果在20毫秒内,`scrollTop`的值没有再次变化,则判断当前的`scrollTop`值是否大于100,如果是,则将组件中的`show`数据设置为true,否则设置为false。
如果在20毫秒内,`scrollTop`的值又发生了变化,则将之前存储的旧的`scrollTop`值和当前的`scrollTop`值进行比较。如果相等,则说明滚动已经停止,可以执行后续的逻辑。如果不相等,则说明滚动仍在进行中,需要继续等待。
`immediate: true`选项表示在组件加载完成后立即执行一次`handler`回调函数,以确保组件在初始化时也能正确处理`scrollTop`的值。
详细解释一下这段代码methods: { handleScroll() { this.handleScrollFn = () => { this.scrollTop = window.scrollY; }; window.addEventListener("scroll", this.handleScrollFn); }, returnFn() { // this.$router.go(-1); console.log(111); }, }, mounted() { this.handleScroll(); }, beforeDestroy() { window.removeEventListener("scroll", this.handleScrollFn); //移除事件监听 }, async created() { try { // 轮播图 let { data } = await getSwiperApi(); this.swiperList = data.data.list; let res = await getGoodsListApi(); this.goodsList = res.data.data.list; // console.log(this.swiperList); // 活动 let active = await getActiveApi(); this.activeList = active.data.data.list; // console.log(this.activeList); } catch (err) { console.log(err); } }, watch: { scrollTop: { handler: function (newValue, oldValue) { clearTimeout(this.timer); this.timer = setTimeout(() => { if (newValue == window.scrollY) { this.oldScrollTop = newValue; if (this.oldScrollTop > 100) { this.searchBgc = "#ccc"; } else { this.searchBgc = "transparent"; } } else { if (this.oldScrollTop == oldValue) { // console.log("滚动开始"); } } }, 20); }, immediate: true, }, },
这是一个Vue.js组件的代码片段,其中包含了一些方法、生命周期函数和watch监听器,具体解释如下:
handleScroll()方法:该方法用于监听页面滚动事件,当页面滚动时,将页面滚动的距离赋值给scrollTop变量。该方法在组件挂载时被调用。
returnFn()方法:该方法暂时被注释掉了,它的作用是返回上一页。
mounted()生命周期函数:该函数在组件挂载后被调用,它调用了handleScroll()方法,监听页面滚动事件。
beforeDestroy()生命周期函数:该函数在组件销毁前被调用,它移除了handleScroll()方法添加的页面滚动事件监听器。
created()生命周期函数:该函数在组件创建完毕后被调用,它使用async/await语法异步获取了轮播图、商品列表和活动列表等数据,并将它们分别赋值给了swiperList、goodsList和activeList等变量。
scrollTop监听器:该监听器监测scrollTop变量的变化,并执行handler函数。handler函数使用setTimeout延迟20毫秒执行,当scrollTop没有发生变化时,将oldScrollTop变量赋值为newValue,然后根据oldScrollTop的值来判断是否需要改变searchBgc的值,从而改变页面顶部搜索框的背景色。当scrollTop发生变化时,不做任何操作。immediate属性被设置为true,表示在监听器添加时立即执行handler函数。
阅读全文