HTML5-CSS3炫酷SELECT下拉菜单美化效果

这是一款使用html5 svg和css3制作的炫酷select下拉菜单美化效果。我们可以通过JavaScript库来将表单中的input元素修改为更加好看的样式,甚至是更复杂的input元素,例如select下拉菜单。我们可以有非常多的表单美化方案,使用户可以得到更加好的用户体验。

在demo中我们使用了下面的字体图标: Ionicons Font Awesome

其中一个demo中使用的SVG国旗是Sean Herron的 Flag Webicons Set

最后一个demo中的圆形图标是Pixel Buddha的Ballicons 2

HTML结构

我们现在来看一下select下拉菜单的Html结构:。

<select class="cs-select cs-skin-rotate">
  <option value="" disabled selected>Choose your option</option>
  <option value="1">Option 1</option>
  <option value="2">Option 2</option>
  <option value="3">Option 3</option>
</select>

我们需要将它转换为下面的结构:

<div class="cs-select cs-skin-rotate">
  <span class="cs-placeholder">Choose your option</span>
  <div class="cs-options">
    <ul>
      <li data-option data-value="1" class="cs-selected"><span>Option 1</span></li>
      <li data-option data-value="2"><span>Option 2</span></li>
      <li data-option data-value="3"><span>Option 3</span></li>
    </ul>
  </div>
  <select class="cs-select cs-skin-rotate">
    <option value="" disabled selected>Choose your option</option>
    <option value="1">Option 1</option>
    <option value="2">Option 2</option>
    <option value="3">Option 3</option>
  </select>
</div>

我们保留实际的select元素是因为我们需要它来选择元素值。

placeholder占位符被设置为disabled,并且设置为空值。它是一个可选项,可以不使用它,这时,第一个列表选项将被显示或者是有“selected”属性的列表项将被显示。

我们可以为select元素设置一个 data-link data-class 属性。 data-link 属性运行在点击列表项时打开一个动态链接。 data-class 属性可以为列表项自定义一个class。

下面还有一些可用参数:

newTab : true,
// open links in new tab (when data-link used in option)
stickyPlaceholder : true,
// when opening the select element, the default placeholder (if any) is shown
onChange : function( val ) { return false; }
// callback when changing the value

stickyPlaceholder用于定义当我们打开select下拉菜单时,占位文本是否每次都被显示。

所有demo的基本样式都定义在cs-select.css文件中。这里我们定义了select下拉菜单的基本样式,使它看起来有扁平化的效果。下面的CSS样式是border效果的select下拉菜单样式效果:

@font-face {
  font-family: 'icomoon';
  src:url('../fonts/icomoon/icomoon.eot?-rdnm34');
  src:url('../fonts/icomoon/icomoon.eot?#iefix-rdnm34') format('embedded-opentype'),
    url('../fonts/icomoon/icomoon.woff?-rdnm34') format('woff'),
    url('../fonts/icomoon/icomoon.ttf?-rdnm34') format('truetype'),
    url('../fonts/icomoon/icomoon.svg?-rdnm34#icomoon') format('svg');
  font-weight: normal;
  font-style: normal;
}
div.cs-skin-border {
  background: transparent;
  font-size: 2em;
  font-weight: 700;
  max-width: 600px;
}
@media screen and (max-width: 30em) {
  .cs-skin-border { font-size: 1em; }
}
.cs-skin-border > span {
  border: 5px solid #000;
  border-color: inherit;
  transition: background 0.2s, border-color 0.2s;
}
.cs-skin-border > span::after,
.cs-skin-border .cs-selected span::after {
  font-family: 'icomoon';
  content: '\e000';
}
.cs-skin-border ul span::after {
  content: '';
  opacity: 0;
}
.cs-skin-border .cs-selected span::after {
  content: '\e00e';
  color: #ddd9c9;
  font-size: 1.5em;
  opacity: 1;
  transition: opacity 0.2s;
}
.cs-skin-border.cs-active > span {
  background: #fff;
  border-color: #fff;
  color: #2980b9;
}
.cs-skin-border .cs-options {
  color: #2980b9;
  font-size: 0.75em;
  opacity: 0;
  transition: opacity 0.2s, visibility 0s 0.2s;
}
.cs-skin-border.cs-active .cs-options {
  opacity: 1;
  transition: opacity 0.2s;
}
.cs-skin-border ul span {
  padding: 1em 2em;
  backface-visibility: hidden;
}
.cs-skin-border .cs-options li span:hover,
.cs-skin-border li.cs-focus span {
  background: #f5f3ec;
}

在线预览 网盘下载

网盘下载密码:3e2c

郑重声明:

1 本资源来源于互联网,资源的版权归资源原作者所持有,受《中华人民共和国著作权法》等相关法律保护。

2 由于无法和原作者取得联系,所以上传的部分资源无法先通过原作者的同意就分享给大家了,如本资源侵犯了您(原作者)的权益,请联系我们(微信号 xiaohaimei1989),我们会立马删除您的资源,并向您表达诚挚的歉意!

3 本站是一个公益型网站,分享资源的目的在于传播知识,分享知识,收取一点点打赏的辛苦费是用于网站的日常运营开支,并非用于商业用途。

4 本站资源只提供学习和参考研究使用,使用过后请在第一时间内删除。本站不承担资源被单位或个人商用带来的法律责任。

发表评论