Zepto 无法阻止冒泡事件的解决
2018-06-24 01:06:16来源:未知 阅读 ()
问题说明:
点击绿色控件不触发红色控件的对应的事件
如图:
Bug: 红色框和绿色框都设置了响应事件,当点击绿色框的时候,红色框的事件也会触发。
解决过程:
查资料
总所周知 js 一般都是使用冒泡流,在翻看《JavaScript高级程序设计》了解到中:
在通过HTML特性指定事件处理程序时,变量event中保存着event对象
把问题独立出来
写个小demo,由于项目内容比较多,容易造成迸发问题;这样也容易定位错误
js 代码如下:
$(document).on("click","#red",function(){ console.log("red"); }); $(document).on("click","#green",function(){ console.log("green"); }); $(document).on("click","#yellow",function(event){ console.log("yellow"); //event.stopPropagation(); });
分析思考与尝试
按照冒泡事件流顺序, 应该是由最具体的控件先行触发:依次是 yellow -> green -> red,实际上这里就是 red -> green -> yellow (按照代码先后顺序输出)
经过无数次确认,语法是没有问题的,后来笔者就怀疑到是不是类库本身的问题?于是就引用了jQuery类库,结果吓了笔者一跳,一样的代码,在jQuery下是没有任何问题的。
后来笔者猜想可能为了轻量级的缘故,削弱了on的功能,抹去他们之间的父子关系
事件绑定在document上致使他们独立出来了导致不能截断冒泡,
于是笔者就修改了下,把他们的父子关系还给他们
$(document).on("click","#red",function(){ console.log("red"); }); $("#red").on("click","#green",function(){ console.log("green"); }); $("#green").on("click","#yellow",function(event){ console.log("yellow"); event.stopPropagation(); });
于是Bug就解决了。
以上,笔者水平有限,如有错漏,敬请指出。
标签:
版权申明:本站文章部分自网络,如有侵权,请联系:west999com@outlook.com
特别注意:本站所有转载文章言论不代表本站观点,本站所提供的摄影照片,插画,设计作品,如需使用,请与原作者联系,版权归原作者所有
- 火狐下input焦点无法重复获取问题的解决方法 2019-12-02
- 微信web开发问题记录 2019-08-14
- 函数节流和函数防抖 2019-04-25
- js 阻止冒泡事件和默认事件 2019-03-13
- Vue单页面应用阻止浏览器记住密码 2019-01-23
IDC资讯: 主机资讯 注册资讯 托管资讯 vps资讯 网站建设
网站运营: 建站经验 策划盈利 搜索优化 网站推广 免费资源
网络编程: Asp.Net编程 Asp编程 Php编程 Xml编程 Access Mssql Mysql 其它
服务器技术: Web服务器 Ftp服务器 Mail服务器 Dns服务器 安全防护
软件技巧: 其它软件 Word Excel Powerpoint Ghost Vista QQ空间 QQ FlashGet 迅雷
网页制作: FrontPages Dreamweaver Javascript css photoshop fireworks Flash