-
-
Notifications
You must be signed in to change notification settings - Fork 193
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
Passive event listeners #62
Comments
Hello @lifedup, Thank you for your question. The answer is no, it's not possible to set all listeners to passive. As far as I understand, passive event listeners matter the most for event listeners that could affect performance like touch and wheel event listeners. So I don't think it makes sense to make all listeners passive by default. As described in this article:
With that said, Embla is using non-passive touch listeners by design. It's intentional. This is because carousels that allow for scrolling in both directions simultaneously have horrible UX. If you've used native CSS scroll snaps in any project, it also prevents intersecting axis scroll just like Embla does. Now I personally think it's unfortunate that tools like lighthouse can be quite blunt in their judgement and rank sites lower because of this. I don't necessarily think that using non passive event listeners is a problem. In most cases you won't even notice it unless you have heavy scroll listeners or similar. I think it's a much bigger problem when devs use heavy scroll listeners without throttles triggered 100 times a second with exaggerated scroll into view effects. But tools like lighthouse probably won't pick that up, even though it will be a much bigger performance hit on the browser. If there is a workaround, I would definitely consider implementing it. I stumbled upon this on Stack Overflow but haven't tried it yet. I’m going to investigate this further 🙂.
In order to debug this, I need information about what device and browser you're using. I also need to see your code to see how you've setup the carousel, and what could be the cause of the jank you're experiencing. Kindly, |
Thanks for the detailed response. I'll look into a few css options on my end in the coming days. Maybe using css overscroll-behavior with touch-action might do the trick when trying to contain the scroll of an overflowed container. I'm also not a huge fan of going strictly by the numbers that the tools like Lighthouse provide. They are great for guidance but should be used on a case by case basis. I'm using google maps and their own tool hits it big on accessibility and performance. I was testing it on an iPhone 11 Pro Max in the latest Safari but the jank stopped when I push the react app to production. |
Hello again @lifedup, I've experimented with the following properties in combination with passive touch listeners in many different ways, in order to recreate Embla's touch drag behaviour:
...with no luck. Any luck on your side? Kindly, |
Hi @lifedup, At this point I've experimented a lot with touch-action and passive listeners to no avail. If you find a way to reproduce the current Embla behavior with passive listeners - please share it. Until then, I'm saying no to this request because it destroys the UX of the carousel. In my opinion, to such an extent that it's unusable on touch devices. Thank you for your request. Cheers! |
@lifedup, @dermotduffy I think I’ve found a way to solve this without changing the Embla behavior so I’ll implement it soon. Stay tuned. |
This feature has been released with v7.0.7. |
I was wondering if there was a way to set all of the event listeners to passive? In the type EventStore the event options are defined but it doesn't' look like in the eventDispatch they are included. Plus I don't see away that you can set them. I'm hoping I overlooked something and there is a way to set them.
I'm getting some jank on mobile with a slider (3 full width image slides + some HTML). Also, I have a client that is adamant about the Google Lighthouse scores (Chrome->Inspector->Audit). This is the only thing I'm getting dinged for in best practices category.
The text was updated successfully, but these errors were encountered: