移动端:active伪类无效的解决方法

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


说到:active伪类就不得不提到:link,:visited,:hover,:active这个四个,最常用的是用于a链接,设定鼠标交互时不同的链接颜色。如下示例:

  1. a:link { /* Essentially means a[href], or that the link actually goes somewhere */  
  2.   colorblue;  
  3. }  
  4. a:visited {  
  5.   colorpurple;  
  6. }  
  7. a:hover {  
  8.   colorgreen;  
  9. }  
  10. a:active {  
  11.   colorred;  
  12. }  
a:link { /* Essentially means a[href], or that the link actually goes somewhere */
  color: blue;
}
a:visited {
  color: purple;
}
a:hover {
  color: green;
}
a:active {
  color: red;
}


上述代码中,将 :visited放到最后,则会导致以下结果:若链接已经被访问过,a:visited会覆盖:active和:hover的样式声明,链接将总是呈现为紫色,无论鼠标悬停还是按下激活,链接都将保持为紫色。

基于此原因,上述代码必须按照顺序定义,一般称为LVHA-order: :link — :visited — :hover — :active,为方便记忆,可记为“LOVE HATE”


L :link
O
V :visited
E


H :hover
A :active
T
E


浏览器兼容性:


ChromeSafariFirefoxOperaIEAndroidiOS
Yep 2.0.4+ any 4+ 4+ TBD TBD


项目中是移动端页面要做一个按钮状态切换的效果,在PC上测试没有问题,到了手机端发现安卓的正常,iOS则没有效果。


源码:

  1. .slotbtn{  
  2.     width5.5rem;  
  3.     height4rem;  
  4.     backgroundurl(../images/sbtn.png) no-repeat 0 0;  
  5.     -webkit-background-size100% auto;  
  6.     background-size100% auto;  
  7.     overflowhidden;  
  8.     cursorpointer;  
  9.     -webkit-tap-highlight-color:transparent;  
  10.     -webkit-user-select:none;  
  11. }  
  12. .slotbtn:active, .slotbtn:focus{  
  13.     background-imageurl(../images/sbtn_active.png);  
  14. }  
.slotbtn{
    width: 5.5rem;
    height: 4rem;
    background: url(../images/sbtn.png) no-repeat 0 0;
    -webkit-background-size: 100% auto;
    background-size: 100% auto;
    overflow: hidden;
    cursor: pointer;
    -webkit-tap-highlight-color:transparent;
    -webkit-user-select:none;
}
.slotbtn:active, .slotbtn:focus{
    background-image: url(../images/sbtn_active.png);
}



html代码:

  1. <div class=“row tc row-sbtn”><span id=“slotbtn” class=“slotbtn”></span></div>  
<div class="row tc row-sbtn"><span id="slotbtn" class="slotbtn"></span></div>

页面截图:

虽然知道jQuery Mobile框架中常会用操作class的方法来进行按钮状态切换,不过觉得非常繁琐,性能不好。而且我们有:active的天然定制属性,为何不用而舍近求远呢??


经过一番查找,之后在mozilla开发社区找到了:active不起作用的答案:


[1] By default, Safari Mobile does not use the :active state unless there is a touchstart event handler on the relevant element or on the <body>.


看来在iOS系统的移动设备中,需要在按钮元素或body/html上绑定一个touchstart事件才能激活:active状态。

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


将上述事件监听代码加上后,Safari Mobile上就可以看到按钮按下后的切换效果了。

参考文章:https://developer.mozilla.org/en-US/docs/Web/CSS/:active

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值