html表单下拉美化教程,html5和css3炫酷select下拉菜单美化效果

html5和css3炫酷select下拉菜单美化效果

发布日期:2015-10-20 11:11

来源:

标签:

网页技术

CSS教程

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结构:

Choose your option

Option 1

Option 2

Option 3

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

Choose your option

  • Option 1
  • Option 2
  • Option 3

Choose your option

Option 1

Option 2

Option 3

我们保留实际的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

}

其它demo的效果你可以通过下载文件中的CSS文件来查看。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值