当内容发生变化时,如何使用 width: auto 对元素的宽度进行动画处理?内容是动态变化的,元素的宽度也应该随着动画的变化而变化。
虽然CSS不直接支持动画自动值,但有两种方法可以实现这种效果:
1。最大宽度/最大高度技巧
.myspan { display: inline-block; font-size: 30px; background-color: #ddd; max-width: 500px; /* Set a sufficiently large max-width */ }
2.基于脚本的宽度设置
$(document).ready(function() { $(".myspan").hover(function() { $(this).width($(this).find("span").outerWidth()); }, function() { $(this).width("auto"); }); });
使用 max-width/max-height 技巧,我们可以创建一个简单的示例,其中元素的宽度在悬停时动画:
.myspan { display: inline-block; font-size: 30px; background-color: #ddd; vertical-align: bottom; } .myspan::after { content: " <pre class="brush:php;toolbar:false"><link href="https://code.ionicframework.com/ionicons/2.0.1/css/ionicons.min.css" rel="stylesheet" /> <span class="myspan">Hello!</span>a0\f12a "; font-family: ionicons; font-size: 80%; display: inline-block; max-width: 0; transition: max-width .6s; vertical-align: bottom; overflow: hidden; } .myspan:hover::after { max-width: 80px; transition: max-width 1s; }
以上是当内容动态变化时,如何使用 CSS 对元素的宽度进行动画处理?的详细内容。更多信息请关注PHP中文网其他相关文章!