html - 最初将宽度设置为适合内容时,CSS宽度过渡不起作用
问题描述
我希望它与width: fit-content
不是数字的属性有关,但我不知道如何在不使用固定宽度的情况下修复它。正如您在下面看到的,当鼠标悬停在上面时,div 不会平滑展开。相反,它们会立即扩展到 100%。
* {
font-family: sans-serif;
}
div:not(#container) {
width: fit-content;
background-color: green;
color: white;
margin-top: 1em;
padding: 1em;
transition-property: width;
transition-duration: 1s;
}
#ease {
transition-timing-function: ease;
}
#linear {
transition-timing-function: linear;
}
#ease-in {
transition-timing-function: ease-in;
}
#ease-out {
transition-timing-function: ease-out;
}
#in-out {
transition-timing-function: ease-in-out;
}
#container:hover div {
width: 90%;
}
<html>
<head>
<title>CSS animations</title>
</head>
<body>
<div id="container">
<div id="linear">
<p>
Linear
</p>
</div>
<div id="ease">
<p>
Ease
</p>
</div>
<div id="ease-in">
<p>
In
</p>
</div>
<div id="ease-out">
<p>
Out
</p>
</div>
<div id="in-out">
<p>
In-out
</p>
</div>
</div>
</body>
</html>
解决方案
你的假设/期望对width: fit-content
我来说似乎是合理的。在有人可以更好地解释之前,您可以使用width: fit-content
with min-width: 0
,然后使用 animate min-width
。它并不完美,因为动画从 0 开始(您可能会注意到轻微的延迟)
* {
font-family: sans-serif;
}
div:not(#container) {
width: fit-content;
min-width: 0;
background-color: green;
color: white;
margin-top: 1em;
padding: 1em;
transition-property: min-width;
transition-duration: 1s;
}
#ease {
transition-timing-function: ease;
}
#linear {
transition-timing-function: linear;
}
#ease-in {
transition-timing-function: ease-in;
}
#ease-out {
transition-timing-function: ease-out;
}
#in-out {
transition-timing-function: ease-in-out;
}
#container:hover div {
min-width: 90%;
}
<html>
<head>
<title>CSS animations</title>
</head>
<body>
<div id="container">
<div id="linear">
<p>
Linear
</p>
</div>
<div id="ease">
<p>
Ease
</p>
</div>
<div id="ease-in">
<p>
In
</p>
</div>
<div id="ease-out">
<p>
Out
</p>
</div>
<div id="in-out">
<p>
In-out
</p>
</div>
</div>
</body>
</html>
推荐阅读
- c# - 修改结构变量
- visual-foxpro - Windows 10 1803 的 VFP 网络问题
- reactjs - 如何将其孩子接受的仅限父母的道具传递给父母?
- javascript - 对于成功的同源请求,Fetch 会抛出“TypeError: Failed to fetch”
- c# - 为什么以及何时需要在异步函数中等待?
- vba - 日期清理功能
- java - 在java中打印以相同字母开头和结尾的字符串中的所有单词
- redux - React Redux 将 action 分发到另一个域进行身份验证
- c++ - 为不同的目标 MCU 开发 C/C++ 代码的区别
- openstack - openstack heat 无法识别 key_name 参数