html - HTML下拉框向下移动html元素
问题描述
所以我试图让下拉列表在展开时与下面的元素重叠。不幸的是,即使同一堆叠上下文中的元素具有位置,并且下拉容器 div 设置为 z-index 2,问题仍然存在;它不会重叠下面的元素,而是将它们向下移动。我还尝试通过将 opacity 属性添加到各种元素来对堆叠上下文进行改组,但这也没有奏效。代码如下:
#firstone {
z-index: 2;
}
#contain {
height: 400px;
width: 400px;
background-color: rgba(100, 25, 25, 0.2);
}
body {
text-align: center;
}
input:focus {
outline: none;
}
.fancy_input_box {
text-align: left;
display: inline-block;
margin: 40px 3% 1px;
position: relative;
}
.fancy_input {
font: 15px/24px "Lato", Arial, sans-serif;
color: #aaa;
box-sizing: border-box;
letter-spacing: 1px;
border: 0;
padding: 7px 7px;
border: 1px solid #ccc;
position: relative;
background: transparent;
}
.fancy_input:focus~.dropdown-content {
display: block;
cursor: default;
}
.fancy_input:focus~.dropdown-content>span {
display: block;
cursor: default;
}
.dropdown-content {
display: none;
background-color: rgba(0, 0, 0, 0.2);
width: 222px;
overflow: auto;
position: relative;
}
.dropdown-content:active {
display: block;
}
.dropdown-content>span {
padding: 12px 16px;
display: none;
}
.dropdown-content>span:hover {
background-color: rgba(0, 0, 0, 0.1);
}
.fancy_input~.fancy_label {
position: absolute;
left: 14px;
width: 100%;
top: 10px;
color: #aaa;
letter-spacing: 0.5px;
transition: 0.3s;
-webkit-transition: 0.3s;
-moz-transition: 0.3s;
z-index: -1;
}
.fancy_input:focus~.fancy_label {
top: -18px;
left: 1px;
font-size: 12px;
color: grey !important;
transition: 0.3s;
-webkit-transition: 0.3s;
-moz-transition: 0.3s;
}
.fancy_input:focus {
border: 1px solid grey !important;
}
.fancy_input:not(focus):valid~.fancy_label {
top: -18px;
font-size: 12px;
left: 1px;
color: #aaa;
transition: 0.3s;
-webkit-transition: 0.3s;
-moz-transition: 0.3s;
}
<!DOCTYPE html>
<html lang="en">
<head>
<link rel="stylesheet" href="test.css">
</head>
<body>
<div id="contain">
<div id="firstone" class="fancy_input_box">
<input class="fancy_input" type="text" placeholder="" maxlength="25" size="25" required>
<label class="fancy_label">Search</label>
<div class="dropdown-content">
<span>a</span>
<span>b</span>
<span>c</span>
<span>d</span>
<span>e</span>
</div>
</div>
<div class="fancy_input_box">
<input class="fancy_input" type="text" placeholder="" maxlength="4" size="10">
<label class="fancy_label">Thing</label>
</div>
<br>
<div>
<div class="fancy_input_box">
<input class="fancy_input" type="text" placeholder="" maxlength="4" size="10">
<label class="fancy_label">stuff</label>
</div>
<div class="fancy_input_box">
<input class="fancy_input" type="text" placeholder="" maxlength="4" size="10">
<label class="fancy_label">more stuff</label>
</div>
<div class="fancy_input_box">
<input class="fancy_input" type="text" placeholder="" maxlength="4" size="10">
<label class="fancy_label">more stuff</label>
</div>
</div>
</div>
</body>
</html>
解决方案
您的下拉内容应该是绝对定位的。
如下所示更新您的下拉样式:
.dropdown-content {
display: none;
background-color: rgba(0, 0, 0, 0.2);
width: 222px;
overflow: auto;
position: absolute;
left: 0;
top: 100%;
}
推荐阅读
- r - 在并行循环中将变量分配给全局环境
- c# - 如何在 Entity Framework Core 中使用另一个对象更新子列表
- javascript - 使用 updateProfile() 函数时如何检查邮件是否已存在于数据库中
- java - java微服务中如何转义,转义字符('\')反斜杠
- c - TUN 接口是否支持 recvmmsg/sendmmsg 在单个系统调用中接收/发送多条消息
- pandas - 在 pandas DataFrame 的每个组中应用 kmeans 并将集群保存在同一 DataFrame 的新列中
- azure - 我可以使用 Azure 身份验证通过 REST API 访问用户消费数据吗
- tensorflow - 创建预训练的权重以在没有暗网/火炬的情况下进行检测
- mysql - 为什么此 SQL 代码可以在 Microsoft Access 数据库中工作,但不能在 phpMyAdmin 中工作?我应该如何改变它才能正常工作?
- azure - 是否可以在 Azure 应用服务中使用通配符设置路径映射?