博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
Jquery事件委托之Safari
阅读量:6693 次
发布时间:2019-06-25

本文共 1174 字,大约阅读时间需要 3 分钟。

什么是事件委托

事件委托是Jquery中一种事件绑定的方式,不同于常见的事件绑定方式将事件绑定在目标元素上,而是将事件绑定在父级元素上通过事件冒泡来执行绑定函数。

//常见的事件绑定(Jquery)$(element).click(function(){    //do something }) //事件委托(Jquery) $(parents).on("click",element,function(){ //do something })

事件委托的原理

事件委托将事件监听绑定在目标元素的父级上,当目标元素响应事件时冒泡到绑定事件的父级上,进行判断该事件的目标元素是否是传入的元素,如果是就执行传入的函数。

//简单实现Jquery的事件委托
    click

    没有做任何的兼容以及其他处理,只是为了了解原理,大家有什么问题可以留言指出。

    事件委托有什么用呢

    说这么多东西,到底事件委托有什么用呢?我认为事件委托最大的好处在于,动态生成的元素还会保留原有的事件绑定。

    //a点击的时候,ul都会新增一个li,新增的li都有绑定事件
    新增li

    今天的主题,事件委托之Sarfari

    一次项目中遇到的问题,click事件委托在移动端的safari上失效了

    加载更多

    看上面的代码,很简单吧,没什么问题吧,除了ios的safari,其他浏览器都能正常的弹出“ok”,一开始想到会不会是什么有地方把冒泡阻止了,但是没有找到,jq的问题?,换了还是不行。正常的绑定(不使用事件委托)没问题,其他想到会不会是jq的bug,如果是jq的bug,那么以前的项目也会有类似的bug,于是到线上去找相关的代码

    test

    在安卓和ios设备上测试,没有任何问题,代码都差不多啊,但是大家注意到没,标签不一样(html语义化多重要啊),于是将p换成a,问题完美解决,最后去谷歌了一下。

    ios的safari中当使用委托给一个元素添加click事件时,如果事件是委托到 document 或 body 上,并且委托的元素是默认不可点击的(如 divspan 等),此时 click 事件会失效。

    原因很清楚了,safari中不可点击元素的click事件不会冒泡到document和body上。

    解决办法

    1.将click事件直接绑定到元素上(不使用事件委托)

    2.需要绑定click事件的元素改成<a>或者<button>等可点击元素

    3.将click事件委托到非doucument或body的父级元素上

    4.给目标元素添加一条css样式 cursor:pointer(推荐这种,方便省事)

    转载于:https://www.cnblogs.com/zh719588366/p/5651475.html

    你可能感兴趣的文章
    Oracle中的JOIN
    查看>>
    html中iframe控制父页面刷新
    查看>>
    每天一个linux命令(50):crontab命令
    查看>>
    linux命令7--cat命令&nl命令
    查看>>
    .NET底层开发技术
    查看>>
    RHEL regiester
    查看>>
    c/c++中的一些基础知识
    查看>>
    练习:输出整数每一位,计算算数,9出现次数,输出图案,水仙花数
    查看>>
    操作系统的发展
    查看>>
    HEVC码流简单分析
    查看>>
    搭建蚂蚁笔记(服务器)
    查看>>
    lnmp
    查看>>
    Oracle教程之Oralce OMF功能详解(三)--使用Oralce OMF管理控制文件
    查看>>
    C# extern 修饰符的用法
    查看>>
    Zabbix修正错误两例(只提供解决思路)
    查看>>
    Redhat6.X 配置HP3PAR7200存储多路径过程
    查看>>
    Java基础系列19:使用JXL或者POI生成和解析Excel文件
    查看>>
    使用xshell打开centos中文显示为乱码
    查看>>
    达内实习——数据库编程、文件读写数据
    查看>>
    zabbix 监控percona
    查看>>