-
Notifications
You must be signed in to change notification settings - Fork 679
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
[css-display] Why is display listed as not animatable instead of animation type: discrete? #6429
Comments
This means that if a CSS animation animated to |
Ah, bummer. "Not animatable" makes total sense then. |
Just for reference, at some point |
I wonder if we could support only specific values of display, e.g. anything but |
Having only some values animateable would be a new concept, but yes, that would work and probably be useful. |
Reopening this to consider allowing animations of display to prevent the element from immediately computing to In particular, my straw-man proposal is the following:
With these two points, we shouldn't have any circularity. An animation cannot itself produce With this, developers could do things like: .hide {
transition: opacity 200ms, display 200ms;
display: none;
opacity: 0;
} Or: @keyframes slideaway {
from { display: block; }
to { transform: translateY(40px); opacity: 0;}
}
.hide {
animation: slideaway 200ms;
display: none;
} |
Just to add on: this should also work for an "entry" animation from |
The CSS Working Group just discussed
The full IRC log of that discussion<fremy> flackr: Display is currently not animatable<fremy> flackr: mostly because none would cancel the animation <fremy> flackr: but there are valid use cases <fremy> flackr: my proposal is to allow animation <fremy> flackr: but flip "none" when the animation reaches 100% only <fremy> flackr: we would need this restriction, because web animations would allow the animation to continue even if the element goes away <fremy> flackr: so, the idea is that if we interpolate between two values <fremy> flackr: the non-"none" value would win <fremy> astearns: what is smfr's take on this? <fremy> astearns: he isn't on the call <fremy> astearns: anybody can take this over for him? <fremy> heycam: at first glance, this seems reasonable <fremy> heycam: I can't see any reason why this would cause issues <PaulG> q+ <fremy> TabAtkins: the fundamental problem is going from "none" to something <fremy> TabAtkins: but there are also values that change box types <fremy> TabAtkins: and that makes it difficult to preserve an animation across box-generation changes <fremy> TabAtkins: but we could define that <fremy> emilio: writing mode an direction can affect animations as well <fremy> fantasai: and text-orientation <fremy> fantasai: but leaving those as non-animatable seems fine <fremy> TabAtkins: that categorization makes sense to me <astearns> ack PaulG <emilio> q+ <fremy> paulg: this can be usedf to keep a distracting and harmful element visible using an animation that never lets "none" apply, troll the user with an animation <ydaniv> q+ <fremy> fantasai: a user stylesheet can disable the animation <fremy> fantasai: so this wouldn't make a difference, I think <fremy> fantasai: there might be bugs in user agents right now, but this is what I expect <fantasai> s/I expect/is specced/ <fremy> PaulG: but !important would not override the animation <fremy> fantasai: no, animations are in the cascade <fremy> fantasai: so !important static would override the animation <fremy> PaulG: so you don't have to override the animation property? <astearns> ack emilio <fremy> fantasai: no, the property is enough <fantasai> -> https://www.w3.org/TR/css-cascade-5/#cascade-sort <fremy> emilio: one question about the behavior: what happens if you put display:none on a keyframe? is that allowed? <fantasai> -> https://drafts.csswg.org/css-cascade-3/implementation-report <fremy> emilio: at parse time that is not allowed <fremy> emilio: but you can sneak this using a custom property <fremy> flackr: yes, we want to make sure some properties should stay within acceptable values <heycam> q+ <fantasai> (Safari currently doesn't handle animations cascade correctly, but Gecko and Blink do) <fremy> emilio: and if doesn't ? what would happen? <fremy> flackr: I guess not having a display value <fremy> emilio: so, make display:none in the animation behave as display:revert (use the value outside of the animation) <fremy> emilio: we can work out the details later though <fremy> flackr: there is no circularity with web animations, so display:none doesn't stop the animation <astearns> ack ydaniv <fremy> emilio: right <fremy> ydaniv: "discrete" animation flip half-way <fremy> ydaniv: can we instead flip where the author wants it? <fremy> flackr: this is the second part of my proposal <fremy> flackr: the value would not change, until you reach the keyframe that sets the value <fremy> ydaniv: and what about other values? <fremy> ydaniv: isn't it more predictible if it always behave as a flip? <fremy> flackr: I think this gives less flexibility to the developers <fremy> flackr: they can still choose to have the keyframes have any duration <fremy> flackr: if you flip immediately, this duration is no longer something the author controls <fremy> astearns: are we not concerned by using a different timing for display than other values? <fremy> ydaniv: I would suppose that other wanting to go from grid to flex don't want to wait <fremy> flackr: all discrete proposals behave like that <fremy> TabAtkins: and you can control where that 50% happens by having another keyframe <astearns> ack heycam <fremy> astearns: but for none, we need something special <fremy> heycam: what about transition:all? <fremy> flackr: no, because all only affects non-discrete properties <fremy> flackr: we could enable transitions for more, but we would probably make a new keyword <fremy> astearns: any other comment on this proposal? <fremy> astearns: any concern about going further? <fremy> astearns: proposed resolution is to adopt and start writing the spec text <fremy> astearns: any objection? <fremy> RESOLVED: adopt this proposal, and work out the details <fantasai> Note: this should go into display-4 |
It's worth noting that the outer display type can already be discretely animated (indirectly, and with side-effects), e.g. by setting |
Comment moved to #8389 |
This isn't part of the landed spec [1], and will be replaced by a combination of these five CSSWG issues: - w3c/csswg-drafts#4441 - w3c/csswg-drafts#6429 - w3c/csswg-drafts#8174 - w3c/csswg-drafts#8189 - w3c/csswg-drafts#8389 After this CL, you will no longer be able to animate your popover like this: ``` [popover] { opacity: 0; transition: opacity 0.2s; } [popover]:open { opacity: 1; } ``` Instead you'll need to use CSS animations or (eventually) transitions and you'll have to explicitly declare the `display` and `top-layer` properties: ``` transition: opacity 0.2s, display 0.2s, top-layer 0.2s; ``` [1] https://html.spec.whatwg.org/multipage/popover.html Bug: 1307772,1413556 Change-Id: I4877dd69a06f2624bdb463b065b2e2b66cbf1154
Chrome 111.0.5545.0 is already supported and requires a Flag:
Demo: https://codepen.io/yisi/pen/RwBzqGE 2023-02-10.15-12-21.mp4 |
This isn't part of the landed spec [1], and will be replaced by a combination of these five CSSWG issues: - w3c/csswg-drafts#4441 - w3c/csswg-drafts#6429 - w3c/csswg-drafts#8174 - w3c/csswg-drafts#8189 - w3c/csswg-drafts#8389 After this CL, you will no longer be able to animate your popover like this: ``` [popover] { opacity: 0; transition: opacity 0.2s; } [popover]:open { opacity: 1; } ``` Instead you'll need to use CSS animations or (eventually) transitions and you'll have to explicitly declare the `display` and `top-layer` properties: ``` transition: opacity 0.2s, display 0.2s, top-layer 0.2s; ``` [1] https://html.spec.whatwg.org/multipage/popover.html Bug: 1307772,1413556 Change-Id: I4877dd69a06f2624bdb463b065b2e2b66cbf1154
I have implemented both display:none->display:revert and flackr's idea here of not canceling the animation when the animation sets the style to display:none. Unless there are edge cases I'm not thinking of, both were similar in difficulty to implement. I don't have a preference yet of which we should go with, but I defer to flackr's judgement. To implement display:none->display:revert, I modified the style resolution code in parts where it knows that the style is being applied for an animation to change display:none to display:revert. It required additional changes in another spot to handle this case with variables: @keyframes hello {
0% { --display-value: none; }
100% { --display-value: none; }
}
#target {
display: var(--display-value, block);
}
#target.animation {
animation-name: hello;
animation-duration: 1s;
} To implement not canceling the animation when an animation sets display:none, I used similar spots in the style resolution code but set a flag on the element when the animation sets display:none, so that the element knows that it shouldn't cancel the animation right after it recalcs its own style. use casesNot canceling the animation provides the ability to animate to display:none and back with keyframes during an animation and actually make the element disappear, but I don't know if that's a use case that we need to support. Here is an example of what that would look like: @keyframes {
0% { display: block; }
20% { display: none; }
80% { display: none; }
100% { display: block; }
}
Due to this @keyframes {
0% { display: block; }
100% { display: none; }
} @keyframes {
0% { display: none; }
100% { display: block; }
} #target {
display: block;
transition: display 1s;
}
#target.animated { display: none; } #target {
display: none;
transition: display 1s;
}
#target.animated { display: block; } |
Thanks @josepharhar for the implementation experience! I believe that changing the cancellation rules for css animations to be only when the base computed style and the animated display style both produce This is also consistent with the way that animations of |
Yeah it turns out that not canceling the animation is much easier to implement, I actually don't need to mess with the style resolution code at all that I mentioned earlier like I did in order to implement the display:revert behavior |
This behavior is being discussed in this CSSWG issue: w3c/csswg-drafts#6429 Fixed: 1411474, 1431719 Change-Id: Ic88aa03ef3ee16f3e59aa01ae53ad2644157e28a
Agenda+ to resolve on the behavior Rob suggested here. |
This behavior is being discussed in this CSSWG issue: w3c/csswg-drafts#6429 Fixed: 1411474, 1431719 Change-Id: Ic88aa03ef3ee16f3e59aa01ae53ad2644157e28a
This behavior is being discussed in this CSSWG issue: w3c/csswg-drafts#6429 Fixed: 1411474, 1431719 Change-Id: Ic88aa03ef3ee16f3e59aa01ae53ad2644157e28a Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4363078 Reviewed-by: Robert Flack <flackr@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1129543}
This behavior is being discussed in this CSSWG issue: w3c/csswg-drafts#6429 Fixed: 1411474, 1431719 Change-Id: Ic88aa03ef3ee16f3e59aa01ae53ad2644157e28a Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4363078 Reviewed-by: Robert Flack <flackr@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1129543}
This behavior is being discussed in this CSSWG issue: w3c/csswg-drafts#6429 Fixed: 1411474, 1431719 Change-Id: Ic88aa03ef3ee16f3e59aa01ae53ad2644157e28a Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4363078 Reviewed-by: Robert Flack <flackr@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1129543}
There is no distinction between computed and animated values, is there? Aren't they one and the same? I asked for this distinction a decade ago in public-fx, because the pattern I call relative animation doesn't need current animated values for interruption. It only ever needs discrete values. Also, the underlying value is not necessarily discrete, which also confused me ten years ago. Is or is not the comment I made almost eight hours before flackr the same solution? This is what I wrote: #6429 (comment)
This is what flackr wrote less than eight hours later: #6429 (comment)
And then yesterday: #6429 (comment)
Can someone please explain the difference? If not, please make the distinction between discrete and animated computed values in specification. Is there a new definition in css-cascade-4, css-cascade-5, or css-cascade-6? They're hard to read since they are in some .bs format (no pun intended). Another question, will something like this be possible? #6429 (comment)
It would make a lot of sense for front-end developers:
Would this work? Can we please make it work? If not, why? |
I think my code suggestion fails on interruption, animating in, then reversing back out. Or, animation and transition rules would need to be different, which isn't good. Still would like discrete and animated computed values, hopefully someone else will too. |
The base word is the key difference here. This is referring to the style before the animations and transitions cascade. The computed value will resolve to However, if the value before the animations part of the cascade is also I've taken a pass at writing the spec updates for this in #8713 |
…y:none animations, a=testonly Automatic update from web-platform-tests CSSDisplayAnimation: Don't cancel display:none animations This behavior is being discussed in this CSSWG issue: w3c/csswg-drafts#6429 Fixed: 1411474, 1431719 Change-Id: Ic88aa03ef3ee16f3e59aa01ae53ad2644157e28a Reviewed-on: https://chromium-review.googlesource.com/c/chromium/src/+/4363078 Reviewed-by: Robert Flack <flackr@chromium.org> Commit-Queue: Joey Arhar <jarhar@chromium.org> Cr-Commit-Position: refs/heads/main@{#1129543} -- wpt-commits: ea6c0f9e17ff602b9cd66e0c5c5724bae9aabe3d wpt-pr: 39148
At the risk of sealioning, I just want to say this will probably not work as is with my (experimental and unapproved by the W3C) desired changes for discrete state: These are flackr's changesets and diffs for my or anyone else's future reference: |
Can you be more specific? In particular,
|
I've been incapacitated, again, but will try to make a coherent proposal to sustyweb. |
The CSS Working Group just discussed
The full IRC log of that discussion<bramus> flackr: Ill take this<bramus> flackr: we resolved to make display animatable but tried to prevent two values of none being animated, but there were lot of edge cases like variables <bramus> flackr: also problem with animate content on pseudos <fantasai> TabAtkins, your proposed <position> syntax has multiple errors so, no. ^_^ <bramus> flackr: if you animate ocntent, it destroys the pseudo <bramus> flackr: added something to css-animations-2 that we only cancel animations if the computed value of display and the value of display before the animoatins cascade is none <bramus> flackr: if an animt produces display none so it continues to run instead of restarting <emilio> q+ <bramus> flackr: beahves like develoeprs expect it to work <bramus> flackr: also consistent with content animations in firebox <bramus> emilio: not sure is content behavior in firefox is intentiional <bramus> emilio: how does this interact with nested elems? <bramus> emilio: presumably we want to cancel animations deep in display none subtrees <bramus> flackr: good q <bramus> flackr: I think there is no lifetime issue if we want to cancel anims in nested elements <bramus> flackr: i would be fine with saying that behaviour should only look at the style without local animaotins and the ancestor style can include all animated styles <bramus> emilio: not sure if i follow <bramus> emilio: when the display value becomes ?? – I think blink also has a mechanism to clear stuff down the tree? <bramus> emilio: presumably we cancel animations then? <bramus> flackr: in blink the anims are associated with the element so we can still remove all of the layout structured associated with it <bramus> flackr: q is if animations keep on living <bramus> flackr: and if their time restarts or not <bramus> flackr: we still need to keep computed style for to plevel display none elem to know it is display none <bramus> flackr: so i thikn that nested elements should just be cancelled to reduce overhead <bramus> emilio: i think we should cancel them, eys <bramus> s/eys/yes/ <bramus> emilio: need to specify when that happens? <bramus> flackr: spec needs a slight change to reflect that it doesnt apply to nested elements <bramus> flackr: can do an update <bramus> emilio: OK <bramus> flackr: Proposed resolution; when an animations produces display none it continues to run but it still cancels animations within that subtree <bramus> Rossen_: Objections? Qs? <bramus> RESOLVED: When an animations produces display none it continues to run but it still cancels animations within that subtree. |
https://www.w3.org/TR/css-display-3/#the-display-properties
I thought we were going for discrete for all properties that can't be intelligently interpolated, and that "not animatable" was reserved primarily for animation properties and the like?
Especially about
display
, there are plenty of use cases where authors want to finish an animation withdisplay: none
, and this prevents them from doing so.The text was updated successfully, but these errors were encountered: