我动态创建了div。对于一些测试,我会去30个div。
每个div底部都有一个按钮栏。我只是想在显示这个栏时,将鼠标悬停在div容器上。
当隐藏这些元素时,div会变小/正在缩小。我想保持这个更大的尺寸,所以只有按钮被隐藏但容器保持其大小。
离开div时,只有按钮会消失。
#wrapper{
padding: 50px;
background-color: red;
}
#content{
color: white;
padding: 10px;
font-size: 20px;
}
#wrapper:hover .btn{
display:block;
}
.btn{
display:none;
}
<div id="wrapper">
<div id="content">
content
</div>
<div>
<button class="btn">
Button 1
</button>
<button class="btn">
Button 2
</button>
<button class="btn">
Button 3
</button>
</div>
</div>
答案 0 :(得分:3)
使用visibility
来控制元素的可见性。它隐藏了元素,但在页面中保留了框架模型的占用区域。
#wrapper{
padding: 50px;
background-color: red;
}
#content{
color: white;
padding: 10px;
font-size: 20px;
}
#wrapper:hover .btn{
visibility:visible;
}
.btn{
visibility:hidden;
}
&#13;
<div id="wrapper">
<div id="content">
content
</div>
<div>
<button class="btn">
Button 1
</button>
<button class="btn">
Button 2
</button>
<button class="btn">
Button 3
</button>
</div>
</div>
&#13;
答案 1 :(得分:2)
使用visibility
代替display
Visibility
将保留元素空间。 display
将删除空格
#wrapper{
padding: 50px;
background-color: red;
}
#content{
color: white;
padding: 10px;
font-size: 20px;
}
#wrapper:hover .btn{
visibility:visible;
}
.btn{
visibility:hidden;
}
&#13;
<div id="wrapper">
<div id="content">
content
</div>
<div>
<button class="btn">
Button 1
</button>
<button class="btn">
Button 2
</button>
<button class="btn">
Button 3
</button>
</div>
</div>
&#13;
答案 2 :(得分:1)
您可以根据需要尝试这两种方法:
使用opacity
。
#wrapper{
padding: 50px;
background-color: red;
}
#content{
color: white;
padding: 10px;
font-size: 20px;
}
#wrapper:hover .btn{
opacity:1;
}
.btn{
opacity:0;
}
&#13;
<div id="wrapper">
<div id="content">
content
</div>
<div>
<button class="btn">
Button 1
</button>
<button class="btn">
Button 2
</button>
<button class="btn">
Button 3
</button>
</div>
</div>
&#13;
使用Q
中的代码,只添加了一个类test-height
var firstHeight = $('.test-height').height();
$('.test-height').height(firstHeight);
$('.btn').hide();
&#13;
#wrapper{
padding: 50px;
background-color: red;
}
#content{
color: white;
padding: 10px;
font-size: 20px;
}
#wrapper:hover .btn{
display:block !important;
}
&#13;
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div id="wrapper">
<div id="content">
content
</div>
<div class="test-height">
<button class="btn">
Button 1
</button>
<button class="btn">
Button 2
</button>
<button class="btn">
Button 3
</button>
</div>
</div>
&#13;
希望这有帮助。