蓝戒的博客


移动端ios:active伪类无效的兼容解决方案

最近做移动端页面,优化UI的时候发现,苹果手机浏览页面中设置的css伪类:active失效。查找资料发现要让css active伪类生效,只需要给这个元素的touchstart/touchend绑定一个空的匿名方法即可成功。

:active伪类常用于设定点击状态下或其他被激活状态下一个链接的样式。最常用于锚点<a href="#">这种情况,一般主流浏览器下也支持其他元素。在多按键的鼠标系统中,:active只适用于主按键,目前的大部分情况都是左键即主键。该伪类下定义的CSS样式只在按下鼠标按钮与释放鼠标按钮之间的短暂瞬间被触发显示。使用键盘的tab键也可以触发:active状态。

说说 设定鼠标交互的四个伪类:link,:visited,:hover,:active;注意将 :visited放到最后,则会导致:若链接已经被访问过,a:visited会覆盖:active和:hover的样式声明,必须按照顺序定义,一般称为LVHA-order: :link — :visited — :hover — :active。

项目中是移动端页面要做一个按钮状态切换的效果,在PC上测试没有问题,到了手机端发现安卓的正常,iOS则没有效果了。原因是在iOS系统的移动设备中,需要在按钮元素或body/html上绑定一个touchstart事件才能激活:active状态。

移动端ios:active伪类失效的兼容解决方案如下:

 

document.body.addEventListener('touchstart', function () { });  //空函数即可

本文固定链接: http://www.webzsky.com/?p=448 | 蓝戒的博客

cywcd
该日志由 cywcd 于2015年05月04日发表在 css, 网页兼容性 分类下, 你可以发表评论,并在保留原文地址及作者的情况下引用到你的网站或博客。
原创文章转载请注明: 移动端ios:active伪类无效的兼容解决方案 | 蓝戒的博客
关键字:

目前共有 4 条留言 【 访客:2 条, 博主:2 条 】双方以 2:2 暂时持平 O(∩_∩)O~

  1. 板凳
    普通:

    求助!加了没用怎么办

    2017-04-20 下午 4:23
    • cywcd:

      document.body.addEventListener(‘touchstart’, function () { alert(1111) });
      测试一下,js有执行嘛

      2017-04-27 下午 5:38
  2. 沙发
    普通:

    我的是:visited无效

    2017-04-20 下午 4:25
    • cywcd:

      请参考一下这篇文章http://www.jianshu.com/p/fa4460e75cd8

      2017-04-27 下午 5:41

发表评论


快捷键:Ctrl+Enter
来自的朋友,欢迎您 点击这里 订阅我的博客 o(∩_∩)o~~~
×