Java自学者论坛

 找回密码
 立即注册

手机号码,快捷登录

恭喜Java自学者论坛(https://www.javazxz.com)已经为数万Java学习者服务超过8年了!积累会员资料超过10000G+
成为本站VIP会员,下载本站10000G+会员资源,会员资料板块,购买链接:点击进入购买VIP会员

JAVA高级面试进阶训练营视频教程

Java架构师系统进阶VIP课程

分布式高可用全栈开发微服务教程Go语言视频零基础入门到精通Java架构师3期(课件+源码)
Java开发全终端实战租房项目视频教程SpringBoot2.X入门到高级使用教程大数据培训第六期全套视频教程深度学习(CNN RNN GAN)算法原理Java亿级流量电商系统视频教程
互联网架构师视频教程年薪50万Spark2.0从入门到精通年薪50万!人工智能学习路线教程年薪50万大数据入门到精通学习路线年薪50万机器学习入门到精通教程
仿小米商城类app和小程序视频教程深度学习数据分析基础到实战最新黑马javaEE2.1就业课程从 0到JVM实战高手教程MySQL入门到精通教程
查看: 435|回复: 0

ios 点击失效、闪屏问题解决方案

[复制链接]
  • TA的每日心情
    奋斗
    2024-11-24 15:47
  • 签到天数: 804 天

    [LV.10]以坛为家III

    2053

    主题

    2111

    帖子

    72万

    积分

    管理员

    Rank: 9Rank: 9Rank: 9

    积分
    726782
    发表于 2021-6-8 17:24:20 | 显示全部楼层 |阅读模式

    一、点击失效

    描述:将点击事件(click)委派在document或者body上,且目标元素为默认不可点击的元素时(非<a>、 <button>而是<span>等),点击失效。

    实例代码:

    <body>
        <div class="page-content">
            <ol class="scence-hot">
                <li data-id="1-1" data-type="1" data-event="J_storeHotBtn"></li>    
            </ol>
        </div>
    </body>

    // 点击事件按钮
    $('body').on('click', '[data-event]', function(e) {
      var arr = $(this).data('event').match(/J_(\w+)Btn/);
      var selector = arr[1];

      switch (selector) {
        case 'storeHot':
          $targetElem = $targetElem.parent('li').length ? $targetElem.parent('li') : $targetElem;
          var type = $targetElem.data('type');
          var id = $targetElem.data('id');
          switch (type) {
            case 1:
              self._createDialog('hot-store', '', id);
              break;
            case 2:
              self._createDialog('hot-hb', '', id);
              break;
            case 3:
              self._createDialog('hot-hb-simple', '', id);
              break;
          }

        break;

      }

    });

    解决办法有五种:

    1、取消事件委派,将事件直接绑定在目标元素本身上;

    2、将目标元素更换成默认可点击的元素,如<a>、<button>;

    3、将事件委派在非document或body上;

    4、将目标元素增加样式cursor:pointer;

    5、将click事件换成touch事件。

    方案3为最佳方案,其他三种的代价相对较大。方案1,不便于代码的管理、性能等;方案2,区块的点击无法实现(语义等方面考虑);方案4,影响展现,会改变原有的交互体验。方案3几乎没有以上几点缺点。

     

    二、点击闪屏

       ios下闪屏问题,由事件委派引发,解决方案如下:    

        1、去除事件委派;

        2、给委派的元素加上属性

          -webkit-tap-highlight-color: rgba(0,0,0,0);

          -webkit-user-select: none;

      方案2为最佳方案。

    哎...今天够累的,签到来了1...
    回复

    使用道具 举报

    您需要登录后才可以回帖 登录 | 立即注册

    本版积分规则

    QQ|手机版|小黑屋|Java自学者论坛 ( 声明:本站文章及资料整理自互联网,用于Java自学者交流学习使用,对资料版权不负任何法律责任,若有侵权请及时联系客服屏蔽删除 )

    GMT+8, 2025-1-11 20:54 , Processed in 0.064208 second(s), 29 queries .

    Powered by Discuz! X3.4

    Copyright © 2001-2021, Tencent Cloud.

    快速回复 返回顶部 返回列表