蓝戒博客

  • 首页
  • 研发说
  • 架构论
  • 效能录
  • AI谈
  • 随笔集
智构苍穹
融合 AI、架构与工程实践,沉淀方法论,构建可持续的技术价值。
  1. 首页
  2. 研发说
  3. 正文

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

2015年5月4日 16909点热度 1人点赞 8条评论

最近做移动端页面,优化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 () { });  //空函数即可
标签: active伪类,移动端ios css 网页兼容
最后更新:2025年9月13日

cywcd

我始终相信,技术不仅是解决问题的工具,更是推动思维进化和创造价值的方式。从研发到架构,追求极致效能;在随笔中沉淀思考,于 AI 中对话未来。

打赏 点赞
< 上一篇
下一篇 >

文章评论

  • 普通

    求助!加了没用怎么办

    2017年4月20日
    回复
    • cywcd

      @普通 document.body.addEventListener('touchstart', function () { alert(1111) });
      测试一下,js有执行嘛

      2017年4月27日
      回复
  • 普通

    求助!加了没用怎么办

    2017年4月20日
    回复
    • cywcd

      @普通 document.body.addEventListener('touchstart', function () { alert(1111) });
      测试一下,js有执行嘛

      2017年4月27日
      回复
  • 普通

    我的是:visited无效

    2017年4月20日
    回复
    • cywcd

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

      2017年4月27日
      回复
  • 普通

    我的是:visited无效

    2017年4月20日
    回复
    • cywcd

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

      2017年4月27日
      回复
  • razz evil exclaim smile redface biggrin eek confused idea lol mad twisted rolleyes wink cool arrow neutral cry mrgreen drooling persevering
    回复 普通 取消回复

    cywcd

    我始终相信,技术不仅是解决问题的工具,更是推动思维进化和创造价值的方式。从研发到架构,追求极致效能;在随笔中沉淀思考,于 AI 中对话未来。

    最新 热点 随机
    最新 热点 随机
    《生化危机》女主手搓AI记忆系统,48小时狂揽7千星!AI的长期记忆终于有解了? 用一条自然语言指令,让AI自动完成了调研、写稿、配音、剪辑全流程 你以为 AI 配音还在拼“像不像”,结果有人已经把“整个语音工作室”开源了 Claude Opus 4.7 上线:编程能力炸裂式跃升,Anthropic 手握更强模型却故意不发布 Gemma 4发布4天即遭"完全越狱",开源AI的安全与自由之争 一个文件让AI写代码不再"翻车":45K星的Karpathy指南火了
    Dan Koe:不想打工?用这套方法把兴趣变成收入GitHub 爆火 4 万星项目:MiroFish,到底是 AI 新神话,还是下一代预测引擎DeerFlow 2.0:字节跳动开源的超级智能体框架,让AI研究、编码、创作一气呵成!Claude Code 生态大爆发:这周 GitHub 热点,已经不是工具升级,而是工作方式重写我把 Codex CLI 装上了“外挂大脑”:oh-my-codex 到底有多猛?别再盲下大模型了:用 llmfit 一秒看懂你的电脑到底能跑谁
    🔥 Nitro v3:全栈开发的新选择,与 Vite 的完美融合 daterangepicker日期范围选择插件使用方法 Vitest 轻量化前端测试的新选择 未来 5 年,谁来证明“你是谁”?AI Agent 时代的身份战场 微信小程序开发资源汇总 Electron vs Tauri:跨平台桌面应用开发如何选型?
    最近评论
    渔夫 发布于 6 个月前(11月05日) 学到了,感谢博主分享
    沙拉小王子 发布于 9 年前(11月30日) 适合vue入门者学习,赞一个
    沙拉小王子 发布于 9 年前(11月30日) 适合vue入门者学习,赞一个
    cywcd 发布于 9 年前(04月27日) 请参考一下这篇文章http://www.jianshu.com/p/fa4460e75cd8
    cywcd 发布于 9 年前(04月27日) 请参考一下这篇文章http://www.jianshu.com/p/fa4460e75cd8

    COPYRIGHT © 2025 蓝戒博客_智构苍穹-专注于大前端领域技术生态. ALL RIGHTS RESERVED.

    京ICP备12026697号-2