问题描述:
今天在调试页面的时候遇到一个奇怪的现象,在一个父元素上面定义了一个点击事件,在父元素下面是一个一个的li标签,这上面没有任何点击事件。现象是当点击其中一个li标签时会发生一些动作。
这个问题困惑了我好久,我对代码翻了好几遍,最后才确定是,点击子元素时也将会触发父元素的事件。当时我把这种现象是在父元素上定义点击事件时,实际上是在这个区域中都定义了点击事件,所以当点击子元素时,实际上也是在点击父元素。
但是更科学的解释是:如果在点击子元素时,如果子元素中没有点击事件,那么该点击事件将自动冒泡到父元素,直到能找到一个可以处理点击事件的函数。
那这种解释可以带来的好处是,可以有方法来屏蔽这种现象,那就是阻止点击事件的冒泡。对于jQuery而言,就是stopPropagation().对于下面的代码而言,大家可以尝试下,如果没有stopPropagation和有stopPropagation之间的差别。
XpShop网络商城系统是新普软件根据多年的电子商务应用实践,结合国际先进技术和国内企业的特点开发出来的一套电子商务购物平台。新普商城系统汇聚国内优秀商城系统的成功元素,傻瓜式的管理后台,人性化的创新体验,风格各异的页面模板,在给您事业带来无限动力的同时,也让您切身感受到新普“简单体验科技”的产品理念。XpShop .Net v6.6具有如下特点:1、使用A
0
代码如下:
<!DOCTYPE html><html><meta http-equiv="content-type" content="text/html;charset=utf8"><link rel="stylesheet" type="text/css" href=""><script src="./jQuery/jquery-2.1.4.js"></script><script type="text/javascript">
$(function() {
$("#mainp").click(function(event) {
if($(this).children('ul').css("display") == "none")
$(this).children('ul').css("display","block"); else
$(this).children('ul').css('display',"none");
});
//阻止向上冒泡
$("#mainp > ul").click(function(event) {
event.stopPropagation();
});
});</script><title>测试如何屏蔽子元素的事件</title><body>
<p id="mainp">
<button>click me</button>
<ul style="display:none">
<li>first</li>
<li>second</li>
<li>third</li>
</ul>
</p></body></html> 更多相关教程请访问 JavaScript视频教程
每个人都需要一台速度更快、更稳定的 PC。随着时间的推移,垃圾文件、旧注册表数据和不必要的后台进程会占用资源并降低性能。幸运的是,许多工具可以让 Windows 保持平稳运行。
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号