-
Notifications
You must be signed in to change notification settings - Fork 243
New issue
Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.
By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.
Already on GitHub? Sign in to your account
using scrollMonitor.recalculateLocations() after a DOM change - how to? #76
Comments
I don't know much about how Vue works, but I suspect it has something to do with the virtual DOM swapping elements. Is there a way to get Vue to give you the DOM element that currently represents the Vue component? If you get it right before your error is it the same as when your component was created? I didn't make any of these so I can't speak to their quality, but there are a few packages that connect Vue and the scroll monitor. |
I've played around with these packages, and unless I'm wrong the first two ones only work when the body is scrolled. The third one does more or less what I'm doing in my project. According to what I can see in Chrome, the Vue's updated Hook is invoked after the div element has been moved in the real DOM. I've tried what they suggest in their documentation:
I call scrollMonitor.recalculateLocations() in that function, but this is not triggering the visibility change callback set on the watcher of the moved element. |
Is the first one the only one that's incorrect or is the first one out of the viewport also incorrect? |
When I invoke scrollMonitor.recalculateLocations(), I would say both. When I scroll, I get visibility change notifications about elements that are not in the viewport, as if the div element had not been moved. When I do not invoke scrollMonitor.recalculateLocations(), the notifications are OK when I scroll. It's just that I don't receive a visibility change notification at the very moment the div element is moved. |
I'm using Vue.js in a project where I have a scroll container and its child elements.
In the scroll container:
In the child elements:
The scroll container passes the scroll monitor to its children through a Vue property.
This works perfectly fine, until an element is moved from one position in the list to another. This is causing the associated DOM element to be moved in the scroll container, and the updated Hook function is called. This Hook function invokes monitor.recalculateLocations() to have the children watchers recalculate their locations and triggers events. But this is not happening (if the element is moved from a position where it is not visible to a position where it is visible in the scroll container, no event is fired), and I would like to understand why.
Example:
The element n is moved to top, resulting in the following changes in the DOM:
The Div for element n is now visible in it's parent scroll container. However, when the scrollMonitor.recalculateLocations() is called, the watcher created for element n does not trigger the visibility change callback.
The text was updated successfully, but these errors were encountered: