华企号 后端开发 利用CSS制作表单组件

利用CSS制作表单组件

案例介绍

欢迎来到我的小院,我是霍大侠,恭喜你今天又要进步一点点了!
我们来用CSS编程实战案例,使用

列表标签完成一个下拉菜单样式的表单部件。

 

案例演示

运行代码后在浏览器弹出由

标签组成的下拉菜单样式的列表。
利用CSS制作表单组件插图

 

源码学习

进入核心代码学习,我们先来看HTML模板中的代码。

<!-- 有个小院-兴趣编程 -->
<div class="select active">
  <span class="value">Cherry</span>
  <ul class="optList">
    <li class="option highlight">Cherry</li>
    <li class="option">Lemon</li>
    <li class="option">Banana</li>
    <li class="option">Strawberry</li>
    <li class="option">Apple</li>
  </ul>
</div>

然后再让我们来看CSS核心代码。

/* 有个小院-兴趣编程 */
*{
  padding: 0px;
  margin: 0px;
}
/* 设置背景色 */
body{
  background-color: #227755;
}
.select {
  /* 设置边框外边距 */
  margin-top: 200px;
  margin-left: 500px;
  /* div为相对定位 */
  position: relative;
  /* div设置为行内块元素 */
  display : inline-block;
}

/* 选择类名为.select元素内的所有类名为.optList的元素 */
.select .optList {
  position: absolute;
  top     : 100%;
  left    : 0;
}

.select .optList.hidden {
  max-height: 0;
  /* 元素不可见 */
  visibility: hidden;
}

/* 设置span标签样式及背景 */
.select {
  /* 字体样式设置 */
  font-size   : 0.625em; /* 10px */
  font-family : Verdana, Arial, sans-serif;

  /* -moz-box-sizing : border-box; */
  box-sizing : border-box;

  padding : 0.1em 2.5em 0.2em 0.5em; /* 1px 25px 2px 5px */
  width   : 10em; /* 100px */

  border        : 0.2em solid #000; /* 2px */
  /* 添加圆角边框 */
  border-radius : 0.4em; /* 4px */

  box-shadow : 0 0.1em 0.2em rgba(0, 0, 0, .45); /* 0 1px 2px */

  background : #F0F0F0;
  background : -webkit-linear-gradient(90deg, #E3E3E3, #fcfcfc 50%, #f0f0f0);
  background : linear-gradient(0deg, #E3E3E3, #fcfcfc 50%, #f0f0f0);
}

.select .value {
  display  : inline-block;
  width    : 100%;
  /* 溢出隐藏 */
  overflow : hidden;
  /* 文本不进行换行 */
  white-space   : nowrap;
  text-overflow : ellipsis;
  vertical-align: top;
  }

  /* 设置下拉框三角标志样式 */
  .select:after {
  content : "▼";
  position: absolute;
  /* 设置元素的堆叠顺序 */
  z-index : 1;
  height  : 100%;
  width   : 2em; /* 20px */
  top     : 0;
  right   : 0;

  padding-top : .1em;

  -moz-box-sizing : border-box;
  box-sizing : border-box;

  text-align : center;

  border-left  : .2em solid #000;
  border-radius: 0 .1em .1em 0;

  background-color : #000;
  color : #FFF;
  }

  /* 设置列表背景样式 */
  .select .optList {
  z-index : 2;
  /* 设置列表项目样式为不使用项目符号,去掉默认样式黑点 */
  list-style: none;
  margin : 0;
  padding: 0;
  /* 设置背景色边框样式 */
  background: #f0f0f0;
  border: .2em solid #000;
  border-top-width : .1em;
  border-radius: 0 0 .4em .4em;

  box-shadow: 0 .2em .4em rgba(0,0,0,.4);

  -moz-box-sizing : border-box;
  box-sizing : border-box;

  min-width : 100%;
  max-height: 10em; /* 100px */
  overflow-y: auto;
  overflow-x: hidden;
  }

  .select .option {
  padding: .2em .3em;
  }

  .select .highlight {
  background: #000;
  color: #FFF;
  }


记得关注我,每天学习一点点

作者: 华企网通王鹏程序员

我是程序员王鹏,热爱互联网软件开发和设计,专注于大数据、数据分析、数据库、php、java、python、scala、k8s、docker等知识总结。 我的座右铭:"业精于勤荒于嬉,行成于思毁于随"
上一篇
下一篇

发表回复

联系我们

联系我们

028-84868647

在线咨询: QQ交谈

邮箱: tech@68v8.com

工作时间:周一至周五,9:00-17:30,节假日休息

关注微信
微信扫一扫关注我们

微信扫一扫关注我们

关注微博
返回顶部