javascript - transition height auto 过渡动画
问题描述
1.为什么收缩时,没有动画效果?
2.代码
<!DOCTYPE html><html lang='en'><head> <title></title> <meta charset='UTF-8'> <meta name='viewport' content='width=device-width, initial-scale=1'> <style>* { transition: all .6s;}.container { position: fixed; top: 0; left: 0; right: 0; height: 100px; max-height: 100px; width: 100px; margin: 5px auto; background: RGBA(0, 43, 54, 0.80); overflow: hidden; text-align: center;}.container:hover { height: auto; max-height: 100%; bottom: 0px;} </style></head><body> <p class='sketch'><p class='container'> <!--<a href='javascript:void(0)'>开关</a>--></p> </p> <!--<script>const classList = document.querySelector(’.container’).classList;document.querySelector(’#switch’).addEventListener(’click’, function (e) { if (classList.contains(’expand’)) {document.querySelector(’.container’).classList.remove(’expand’); } else {document.querySelector(’.container’).classList.add(’expand’); }}); </script>--></body></html>
3.在线Demo(己解决)
问题解答
回答1:因为我们所能看到的过渡动画,其实是height值的变化过程,而你在hover属性中,并没有给height赋予明确的值,因此在移出鼠标之后,浏览器其实并不知道该从哪个值变化到初始值,于是就直接返回到初始值,所以没有过渡效果
回答2:原因如1楼所说。可以设置height:100%;。
回答3:.container:hover { height: 100%; // 这个要明确值 max-height: 100%; bottom: 0px;}
相关文章:
1. 为什么我ping不通我的docker容器呢???2. 关于docker下的nginx压力测试3. 服务器端 - 采用nginx做web服务器,C++开发应用程序 出现拒绝连接请求?4. angular.js - Ionic 集成crosswalk后生成的apk在android4.4.2上安装失败???5. javascript - nidejs环境设置操作一直出现这种问题怎么解决?6. python - pandas按照列A和列B分组,将列C求平均数,怎样才能生成一个列A,B,C的dataframe7. dockerfile - [docker build image失败- npm install]8. java - Tomcat 不同的域名访问同一个项目的不同网页9. javascript - Angular controlller控制域和原生js的关系10. java - 静态属性中的赋值和静态代码块中的赋值有什么区别?
