[webkit移动开发笔记]之如何去除android上a标签产生的边框(转)

转载地址:http://www.cnblogs.com/PeunZhang/archive/2013/02/28/2907708.htmlcss

去年年末,作完最后一个项目就能够开开心心回家,但是在测试阶段,发现了很多bug,为了避免影响回家时间,加班加点也要解决这些问题,这里算是工做回忆,也算是工做的一点小总结。html

在ios4+和android2+系统,当手指触摸屏幕a标签连接或按钮时,会产生不一样的效果,对于ios点击元素的时候,就会出现一个半透明的灰色背景;对于android则出现红色的边框。对这2个系统自带的效果,这种体验的意义无非为了告知用户按钮已经点击到,带来的价值是好的。惋惜带来了体验的同时,也带来了bug......android

主要是在android手机的一个bugios

使用css给模块设置了opacity:0,控制该模块隐藏,若是该模块包含a标签,其a标签在android手机是能够被触发的,而在iphone是不能够触发。web

下图左图为模块一,当页面内容未加载完成时,显示该模块;右图为模块二,当页面内容彻底加载成功后才显示该模块,模块二经过设置了彻底透明使其隐藏在模块一的上一层级。浏览器

 

在android手机中,当处于模块一状态时,用户触摸到“查看按钮”,a标签的边框显示出来,这明显不是咱们要想要的体验。网络

最后跟产品经理沟通后,针对android手机去除上图的按钮边框,那么如何去除android手机自带的按钮边框呢?iphone

在搜索引擎中找到资料-webkit-tap-highlight-color能够去除边框,以下图:测试

排除误解搜索引擎

网络资料说这个属性只用于iOS(iPhone和iPad),实际上是错误的,android手机大部分也是支持的,只是显示效果不同,移动开发并不成熟,更多的还须要你们去实践来辨别真伪- -

-webkit-tap-highlight-color用法

webkit内核的浏览器,当用户点击一个连接或者经过js定义的可点击元素的时候,会出现一个半透明的灰色背景或者红色的边框。

若是想要禁用高亮,可设置颜色的alpha值为0,也就是属性值的最后一位设置为0就能够去除背景或者边框。

去除android连接触摸时产生边框的css代码

a,button,input{-webkit-tap-highlight-color:rgba(255,0,0,0);}/* 1.去除android a/button/input标签被点击时产生的边框 2.去除ios a标签被点击时产生的半透明灰色背景 */

ok~搞定

通常咱们设置:

* { -webkit-tap-highlight-color: rgba(0,0,0,0); /* 1.去除android a/button/input标签被点击时产生的边框 2.去除ios a标签被点击时产生的半透明灰色背景 */ }

相关文章
相关标签/搜索