CSS3 重置iphone浏览器按钮input,select等表单元素的默认样式


Posted in HTML / CSS onOctober 11, 2014

今天在公司写了一个登录页面效果,让我碰到一个怪异的问题——“表单中的input[type="submit"]和input[type="reset"]按钮在iPhone的safari浏览器下圆角有一个bug”。下面我来简单的描述一下这个bug的样子:

初载入页面后,表单中的input[type="submit"]和input[type="reset"]按钮渲染成下图的样子:

CSS3 重置iphone浏览器按钮input,select等表单元素的默认样式
奇怪的是你点击以后就会正常:

CSS3 重置iphone浏览器按钮input,select等表单元素的默认样式

或许很多同学会认为我的样式代码没写好,那么想让大家知道是怎么一回事,先来看看我写的代码:

input[type="submit"]和input[type="reset"]样式代码:

复制代码
代码如下:
.form-actions input{
width: 30%;
cursor: pointer;
background: rgb(61, 157, 179);
padding: 8px 5px;
font-family: 'BebasNeueRegular','Arial Narrow',Arial,sans-serif;
color: #fff;
font-size: 24px;
margin: 5px;
border: 1px solid rgb(28, 108, 122);
margin-bottom: 10px;
text-shadow: 0 1px 1px rgba(0, 0, 0, 0.5);
border-radius: 3px;
box-shadow:0px 1px 6px 4px rgba(0, 0, 0, 0.07) inset,
0px 0px 0px 3px rgb(254, 254, 254),
0px 5px 3px 3px rgb(210, 210, 210);
-webkit-transition: all 0.2s linear;
transition: all 0.2s linear;
}
.form-actions input:hover{
background: rgb(74, 179, 198);
}
.form-actions input:active,
.form-actions input:focus{
background: rgb(40, 137, 154);
position: relative;
top: 1px;
border: 1px solid rgb(12, 76, 87);
box-shadow: 0px 1px 6px 4px rgba(0, 0, 0, 0.2) inset;
}

这样的代码在浏览器中浏览是完全没有问题的:

注:请使用safari测试上面代码。
可是上面的代码就在iPhone的Safari浏览器下出开头所陈述的问题。一下真不好如何动手解决,因为从来没有接触过,所以就一直没有碰到过。 但问题出了,就要想办法解决,于是在GG上搜索“input submit for iPhone”,还真找到了问题所在。 Keir Whitaker 在Styling Submit Buttons for Mobile Safari 中介绍的内容和我碰到的问题可真是一模一样,按其方法在样式中加入:



复制代码代码如下:
.form-actions input{
 ...
 -webkit-appearance: none;
 }
更新到iPhone一看,真爽,问题解决了。

原来问题出在这里,iPhone上的safari解析input[type="submit"]和input[type="reset"]按钮会以 苹果浏览器的默认UI渲染,这样就出现我刚才那种现像,我们在样式中明确的设置了button的圆角值,但到iPhone的safari上就不生效了。要 想让他生效,就需要在样式中明确的指名:



复制代码代码如下:
.form-actions input{
 ... 
 -webkit-appearance: none;  }
在不同的“-webkit-appearance”选值情况下,button所渲染的效果是不一样的,详细的测试代码大家可使用safari浏览器点击这 里。有关于“-webkit-appearance”的详细介绍,这回算是知道了,最后我建议大家,我们可以直接在“reset.css”样式文件中加处 这么一句:



复制代码代码如下:
input[type="submit"],
 input[type="reset"],
 input[type="button"],
 button { -webkit-appearance: none; }
这样一来就不会为这样的问题头痛了。
如果你还没有碰到,或者你也在开发移动端web,都希望你记住这个小技巧,因为当你在制作中碰到这样的问题时,不会为此抓破头皮,能解决你问题。最后希望大家喜欢这篇文章,如果你觉得对你有所帮助,可以推荐给你的朋友,谢谢阅读。
HTML / CSS 相关文章推荐
收集的22款给力的HTML5和CSS3帮助工具
Sep 14 HTML / CSS
纯CSS实现聊天框小尖角、气泡效果
Apr 04 HTML / CSS
使用css3实现超炫的loading加载动画效果
May 07 HTML / CSS
利用SVG和CSS3来实现一个炫酷的边框动画
Jul 22 HTML / CSS
CSS实现聊天气泡效果
Apr 26 HTML / CSS
涂鸦板简单实现 Html5编写属于自己的画画板
Jul 05 HTML / CSS
HTML5 本地存储之如果没有数据库究竟会怎样
Apr 25 HTML / CSS
html5教程画矩形代码分享
Dec 04 HTML / CSS
浅谈利用缓存来优化HTML5 Canvas程序的性能
May 12 HTML / CSS
基于HTML5实现类似微信手机摇一摇功能(计算摇动次数)
Jul 24 HTML / CSS
CSS中Single Div 绘图技巧的实现
Jun 18 HTML / CSS
CSS3 Tab动画实例之背景切换动态效果
Aug 23 HTML / CSS
css3 图片圆形显示 如何CSS将正方形图片显示为圆形图片布局
Oct 10 #HTML / CSS
css3弹性盒模型(Flexbox)详细介绍
Oct 08 #HTML / CSS
一款纯css3实现的动画加载导航
Oct 08 #HTML / CSS
css3 transform属性详解
Sep 30 #HTML / CSS
让IE支持CSS3的不完全兼容方案
Sep 19 #HTML / CSS
一款css实现的鼠标经过按钮的特效
Sep 11 #HTML / CSS
纯CSS3发光分享按钮的实现教程
Sep 06 #HTML / CSS
You might like
php表单请求获得数据求和示例
2014/05/15 PHP
php上传大文件设置方法
2016/04/14 PHP
PHP实现求连续子数组最大和问题2种解决方法
2017/12/26 PHP
ThinkPHP框架获取最后一次执行SQL语句及变量调试简单操作示例
2018/06/13 PHP
免费空间广告万能消除代码
2006/09/04 Javascript
javascript中的继承实例代码
2011/04/27 Javascript
Javascript基础 函数“重载” 详细介绍
2013/10/25 Javascript
javascripit实现密码强度检测代码分享
2013/12/12 Javascript
悬浮数字的实现案例
2014/02/19 Javascript
NodeJS Express框架中处理404页面一个方式
2014/05/28 NodeJs
Javascript将双字节字符转换成单字节字符并计算长度
2016/06/22 Javascript
js精准的倒计时函数分享
2016/06/29 Javascript
js常用DOM方法详解
2017/02/04 Javascript
Javascript实现登录记住用户名和密码功能
2017/03/22 Javascript
es6+angular1.X+webpack 实现按路由功能打包项目的示例
2017/08/16 Javascript
react.js组件实现拖拽复制和可排序的示例代码
2018/08/20 Javascript
浅谈Angular 观察者模式理解
2018/11/01 Javascript
详解ES6中的Map与Set集合
2019/03/22 Javascript
浅谈Scrapy框架普通反爬虫机制的应对策略
2017/12/28 Python
python3+PyQt5实现支持多线程的页面索引器应用程序
2018/04/20 Python
Python绘制3D图形
2018/05/03 Python
Python二进制串转换为通用字符串的方法
2018/07/23 Python
Django框架视图层URL映射与反向解析实例分析
2019/07/29 Python
python 批量修改 labelImg 生成的xml文件的方法
2019/09/09 Python
PyCharm使用之配置SSH Interpreter的方法步骤
2019/12/26 Python
Python数据模型与Python对象模型的相关总结
2021/01/26 Python
猫途鹰英国网站:TripAdvisor英国(旅游社区和旅游评论)
2016/08/30 全球购物
美国时尚女装在线:Missguided
2016/12/03 全球购物
佳能德国网上商店:Canon德国
2017/03/18 全球购物
党员年终民主评议的自我评价
2013/11/05 职场文书
财务工作个人求职的自我评价
2013/12/19 职场文书
《埃及的金字塔》教学反思
2014/04/07 职场文书
国际经济贸易专业自荐信
2014/06/13 职场文书
4s店销售经理岗位职责
2014/07/19 职场文书
MySQL 使用事件(Events)完成计划任务
2021/05/24 MySQL
python运行脚本文件的三种方法实例
2022/06/25 Python