📜  基础 CSS 下拉显式定位(1)

📅  最后修改于: 2023-12-03 15:37:49.137000             🧑  作者: Mango

基础 CSS 下拉显式定位

在 Web 开发中,下拉选择框是一个常见的功能,例如在表单中选择性别、年龄、地区等信息时都需要使用下拉选择框。在 CSS 中,我们可以使用 position 属性来定位下拉框,同时使用 z-index 属性来设置它的图层,保证它能够在其他元素之上显示。

实现下拉选择框

首先,我们需要先创建一个下拉选择框的 HTML 结构,它通常由一个按钮和一个下拉菜单组成:

<div class="dropdown">
  <button class="dropbtn">选择</button>
  <div class="dropdown-content">
    <a href="#">选项 1</a>
    <a href="#">选项 2</a>
    <a href="#">选项 3</a>
  </div>
</div>

这里的 .dropdown 元素是最外层的容器,.dropbtn 是单击触发下拉菜单的按钮,而 .dropdown-content 则是下拉菜单的内容区域。

接下来,我们可以为 .dropdown-content 设置以下 CSS 样式来隐藏它,等到需要时再动态地显示出来:

.dropdown-content {
  display: none;
  position: absolute;
  z-index: 1;
}

在这里,我们使用 position: absolute 将下拉菜单的位置设置为相对于最近的有 position: relativeposition: absolute 属性的父元素进行定位,如果没有,则相对于浏览器窗口进行定位。而 z-index: 1 则用于设置它的图层,确保它显示在其他元素的上方。

动态显示下拉菜单

接下来,我们需要使用 JavaScript 或 jQuery 等脚本语言来实现菜单的显示和隐藏。这里我们以 jQuery 为例:

$(".dropbtn").click(function(){
  $(".dropdown-content").toggle();
});

这个代码片段使用了 jQuery 的 click() 方法来监听按钮单击事件,然后使用 toggle() 方法来切换下拉菜单的显示状态。

完整代码

了解了上面两个步骤后,我们就可以将它们组合起来,实现一个完整的下拉选择框:

<!DOCTYPE html>
<html>
<head>
<style>
/* 下拉选择框的按钮样式 */
.dropbtn {
  background-color: #4CAF50;
  color: white;
  padding: 12px;
  font-size: 16px;
  border: none;
  cursor: pointer;
}

/* 下拉选择框的按钮下拉菜单 */
.dropdown {
  position: relative;
  display: inline-block;
}

/* 下拉选择框的按钮下拉菜单内容 */
.dropdown-content {
  display: none;
  position: absolute;
  z-index: 1;
}

/* 下拉选择框的按钮下拉菜单选项 */
.dropdown-content a {
  color: black;
  padding: 12px 16px;
  text-decoration: none;
  display: block;
}

/* 下拉选择框的按钮下拉菜单选项鼠标悬停样式 */
.dropdown-content a:hover {background-color: #f1f1f1;}

/* 取消所有列表样式 */
ul.dropdown-ul {
  list-style: none;
  margin: 0;
  padding: 0;
}

/* 设置 body 边距 */
body {
  margin: 0;
  padding: 0;
}

/* 设置页面区域的内边距和背景颜色 */
.page-wrapper {
  padding: 20px;
  background-color: #f5f5f5;
}
</style>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/3.5.1/jquery.min.js"></script>
<script>
$(document).ready(function(){
  $(".dropbtn").click(function(){
    $(".dropdown-content").toggle();
  });
});
</script>
</head>
<body>
<div class="page-wrapper">
  <div class="dropdown">
    <button class="dropbtn">选择</button>
    <div class="dropdown-content">
      <a href="#">选项 1</a>
      <a href="#">选项 2</a>
      <a href="#">选项 3</a>
    </div>
  </div>
</div>
</body>
</html>

这个代码片段中,我们不仅实现了下拉选择框的功能,还对其进行了一些样式的调整,让它看上去更美观。最终的效果如下图所示:

dropdown-example

以上就是基础 CSS 下拉显式定位的介绍和实现方法,希望对你有所帮助。