I have a very simple app, that has 2 components: the App.vue
and another component, Home.vue
where I hold the rest of the structure of the app: a sticky header and some sections with anchors to scroll to.
I want to apply a class to the sticky header to minimize the logo while the page is scrolled. So I thought I'd watch for any changes in window.scrollY
. So if scrollY
is greater than 0, apply some class that minimizes the logo.
I tried to listen to scroll events in my component, but that didn't go very far. In this discussion here, a very good solution is provided, but I don't know where to place the scroll event. https://github.com/vuejs/Discussion/issues/324
So, I thought the most fitting solution would be to create a data property, assign it the window.scrollY
figure and then watch for changes in its value. Unfortunately, the watcher is never triggered. So now I'm stuck. The code is:
data () {
return {
...
windowTop: window.top.scrollY
}
}
...
watch: {
windowTop: {
immediate: true,
handler (newVal, oldVal) {
console.log(newVal, oldVal);
},
}
}
Any ideas of what I might be doing wrong?