-
Notifications
You must be signed in to change notification settings - Fork 4.3k
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
JIT: Optimize universal selector usage by inlining only the relevant selectors #4850
Conversation
Drop all newlines, let prettier handle everything for us.
Hi! Is there a Github issue about the performance problems this PR intended to solve? 2.2.5 has saved our lives and we have pinned the version because this change gets rolled back consequently. I wanted to describe our case in the issue but I failed to find any. |
Hi, Using TW 2.2.9 and JIT. We are building mobile first website (ReactJS, TS, NextJS, FramerMotion) and we are always testing performance on iPhone5( as lower end benchmark). There are about 700-800 dom elements on the main page. I was attempting to add Tailwind to the project and it resulted in very choppy performance iPhone 5 - loosing frames in animation, content disappearing while scrolling. On newer phones it is less noticeable but there is a slowdown. After 2 days of breaking everything down I found out that @tailwind utilities; was making all the difference, now reading this tread I see that only the universal selector from utilities is making the difference. I have substituted @tailwind utilities; with the compiled CSS and narrowed it down, that cutting below code, makes visible impact on performance.
I hope it helps! |
@adamwathan, I noticed that you have rolled back this fix. Will you be adding it again at a later stage? |
@adamwathan I have just tested v2.2.10 with the experimental flag
Our website speed (perceived fluidity of scrolling and animations) with above flag is back to stage before adding Tailwind. No side effects noticed. |
Currently (especially in JIT) we make heavy use of the universal selector (
*
) to do these sort of "resets" for composable utilities,transform
for example:It turns out reading/writing to CSS variables can be expensive on site that have a lot of DOM nodes (like the Tailwind CSS home page) and that causes things to render more slowly than they really should have to if you only apply those rules when needed.
This PR adds a separate optimization step that ensures what used to be the universal selector is replaced with only the selectors needed, so the output looks more like:
...where the selectors included are all of the ones used in your template files that depend on this reset.
To make this work, we've added a new
@defaults
at-rule, which we consider private API for now until we're sure it's the correct abstraction.