CSS3美化表单控件全集
网站建设 2023-01-28 21:38www.1681989.com免费网站
表单的默认控件在不同的浏览器中的样式不同,用户体验很差。用CSS3可以实现表单控件的美化,可以提供更好的用户体验。不足之处就是浏览器的兼容性问题。
一.下拉控件
效果图
下拉控件的布局结构
XML/HTML Code复制内容到剪贴板
- <div class="contaer">
- <div class="select">
- <p>所有选项</p>
- <ul>
- <li class="selected" data-value="所有选项">所有选项</li>
- <li data-value="Python">Python</li>
- <li data-value="Javascript">Javascript</li>
- <li data-value="Java">Java</li>
- <li data-value="Ruby">Ruby</li>
- </ul>
- </div>
- </div>
ul用来模拟下拉列表,在实际的使用过程中,可以根据后台返回过来的数据动态生成。p元素用来渲染选中的选项。
核心样式
CSS Code复制内容到剪贴板
- .contaer .select{
- width: 300px;
- height: 40px;
- font-size: 14px;
- background-color:#fff;
- marg-left: auto;
- marg-right: auto;
- position: relative;
- }
- /下拉箭头的样式/
- .contaer .select:after{
- content: "";
- display: block;
- width: 10px;
- height: 10px;
- position: absolute;
- : 11px;
- rightright: 12px;
- border-left: 1px solid #c;
- border-bottom: 1px solid #c;
- -webkit-transform: rotate(-45deg);
- transform: rotate(-45deg);
- -webkit-transition: transform .2s ease-, .2s ease-;
- transition: transform .2s ease-, .2s ease-;
- }
- /
- 被选中的列表项显示的区域
- /
- .contaer .select p{
- paddg: 0 15px;
- le-height: 40px;
- cursor: poter;
- }
- /
- 下拉列表的样式
- 默认高度为0
- /
- .contaer .select ul{
- list-style: none;
- background-color: #fff;
- width: 100%;
- overflow-y: auto;
- position: absolute;
- : 40px;
- left: 0;
- max-height:0;
- -webkit-transition: max-height .3s ease-;
- transition: max-height .3s ease-;
- }
- .contaer .select ul li{
- paddg: 0 15px;
- le-height: 40px;
- cursor: poter;
- }
- .contaer .select ul li:hover{
- background-color: #e0e0e0;
- }
- .contaer .select ul li.selected{
- background-color: #39f;
- color: #fff;
- }
- /下拉控件动画/
- @-webkit-keyframes slide-down{
- 0%{
- -webkit-transform: scale(1, 0);
- transform: scale(1, 0);
- }
- 25%{
- -webkit-transform: scale(1, 1.2);
- transform: scale(1, 1.2);
- }
- 50%{
- -webkit-transform: scale(1, .85);
- transform: scale(1, .85);
- }
- 75%{
- -webkit-transform: scale(1, 1.05);
- transform: scale(1, 1.05);
- }
- 100%{
- -webkit-transform: scale(1, 1);
- transform: scale(1, 1);
- }
- }
- @keyframes slide-down{
- 0%{
- -webkit-transform: scale(1, 0);
- transform: scale(1, 0);
- }
- 25%{
- -webkit-transform: scale(1, 1.2);
- transform: scale(1, 1.2);
- }
- 50%{
- -webkit-transform: scale(1, .85);
- transform: scale(1, .85);
- }
- 75%{
- -webkit-transform: scale(1, 1.05);
- transform: scale(1, 1.05);
- }
- 100%{
- -webkit-transform: scale(1, 1);
- transform: scale(1, 1);
- }
- }
- .contaer .select.on ul{
- /
- 默认情况下,ul的高度为0,当点击控控件的时候,
- 设置下拉列表的高度。
- /
- max-height: 300px;
- -webkit-transform-orig: 50% 0;
- transform-orig: 50% 0;
- -webkit-animation: slide-down .5s ease-;
- animation: slide-down .5s ease-;
- }
- /下拉选项被选中后控制箭头的方向/
- .contaer .select.on:after{
- -webkit-transform: rotate(-225deg);
- transform: rotate(-225deg);
- : 18px;
- }
这里只是静态的样式,如果要实现“选择”这个过程,需要用到JavaScript来实现。
JavaScript Code复制内容到剪贴板
- $(function(){
- var selected = $('.select > p');
- //控制列表显隐
- selected.on('click', function(event){
- $(this).parent('.select').toggleClass('on');
- event.sPropagation();
- });
- //点击列表项,将列表项的值添加到p标签中
- $('.select li').on('click', function(event){
- var self = $(this);
- selected.text(self.data('value'));
- });
- //点击文档其他区域隐藏列表
- $(document).on('click', function(){
- $('.select').removeClass('on');
- });
- });
二.美化单选框
lable标签可以通过for属性与单选框实现联动。我们利用这一特性来实现美化单选框,这也是原理所在。还有就是别忘了将真正的单选框(type="radio")隐藏掉。
CSS Code复制内容到剪贴板
- /用过label标签来模拟radio 的样式/
- .radio-block label{
- display: le-block;
- position: relative;
- width: 28px;
- height: 28px;
- border: 1px solid #;
- background-color: #fff;
- border-radius: 28px;
- cursor: poter;
- marg-right:10px;
- }
- put[type="radio"]{
- display: none;
- }
- .radio-block label:after{
- content: '';
- display: block;
- position: absolute;
- width: 20px;
- height: 20px;
- left: 4px;
- : 4px;
- background-color: #28bd12;
- border-radius: 20px;
- /通过scale属性来控制中心点/
- -webkit-transform: scale(0);
- transform: scale(0);
- }
- /选中样式/
- put[type="radio"]:checked + label{
- background-color :#eee;
- -webkit-transition: background-color .3s ease-;
- transition: background-color .3s ease-;
- }
- /选中之后的样式/
- put[type="radio"]:checked + label:after{
- -webkit-transform: scale(1);
- transform: scale(1);
- -webkit-transition: transform .2s ease-;
- transition: transform .2s ease-;
- }
效果
三.美化复选框
原理和单选框的制作方式类似。在checked的时候该表圆形的left值和label的背景。
CSS Code复制内容到剪贴板
- .switch-block{
- width: 980px;
- paddg: 3% 0;
- marg: 0 auto;
- text-align: center;
- background-color: #fc9;
- }
- .switch-block label{
- display: le-block;
- width: 62px;
- height: 30px;
- background-color:#fafafa;
- border:1px solid #eee;
- border-radius: 16px;
- position: relative;
- marg-right: 10px;
- cursor: poter;
- -webkit-transition: background .2s ease-;
- transition :background .2s ease-;
- }
- put[type="checkbox"]{
- display: none;
- }
- .switch-block label:after{
- content: '';
- position: absolute;
- width: 28px;
- height: 28px;
- border: 1px solid #eee;
- border-radius: 14px;
- left: 1px;
- background-color:#fff;
- -webkit-transition: left .2s ease-;
- transition: left .2s ease-;
- }
- .switch-block put[type="checkbox"]:checked + label{
- background-color:#3c6;
- -webkit-transition: background .2s ease-;
- transition :background .2s ease-;
- }
- .switch-block put[type="checkbox"]:checked + label:after{
- left: 32px;
- -webkit-transition: left .2s ease-;
- transition: left .2s ease-;
- }
本文链接
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持狼蚁SEO。
上一篇:CSS3+DIV实现漂亮的动画彩色标签
下一篇:CSS3字体效果的设置方法小结
网站设计
- 静宁会SEO的网站建设公司:全面提升您的网络影
- 提升在线业务的关键:选择最佳的丽水网站建设
- 浙江网站优化发展潜力如何
- 井研专业的网站建设公司:打造您的在线品牌
- 灵山SEO网站建设公司:提升您的在线业务表现
- 蒙城网站建设优化公司:提升您网站表现的理想
- 阳谷企业网站优化:提升线上业务力的关键
- 樟树专业的网站建设公司:打造您在线业务的坚
- 通河百度SEO排名的策略与技巧
- 重庆百度快照排名如何进行精准的客户引流
- 重庆百度快照排名
- 常宁便宜的建站公司:助您轻松打造在线业务
- 巫溪百度网站优化:提升网站曝光率与流量的关
- 湖北整站优化怎么做才能放大客户需求
- 闸北网站建设多少钱?全面解析与预算规划
- 辽宁企业网站优化怎么做电话营销