码迷,mamicode.com
首页 > 其他好文 > 详细

阻止默认行为和冒泡

时间:2017-05-14 16:13:34      阅读:196      评论:0      收藏:0      [点我收藏+]

标签:链接   default   函数   tty   讲解   对象   turn   ams   dom   

preventDefault方法的起什么作用呢?我们知道比如<a href="http://www.baidu.com">百度</a>,这是html中最基础的东西,起的作用就是点击百度链接到http://www.baidu.com,这是属于<a>标签的默认行为,而preventDefault方法就是可以阻止它的默认行为的发生而发生其他的事情。

stopPropagation方法呢?讲stopPropagation方法之前必需先给大家讲解一下js的事件代理。

事件代理用到了两个在JavaSciprt事件中常被忽略的特性:事件冒泡以及目标元素。当一个元素上的事件被触发的时候,比如说鼠标点击了一个按钮,同样的事件将会在那个元素的所有祖先元素中被触发。这一过程被称为事件冒泡;这个事件从原始元素开始一直冒泡到DOM树的最上层。对任何一个事件来说,其目标元素都是原始元素,在我们的这个例子中也就是按钮。目标元素它在我们的事件对象中以属性的形式出现。使用事件代理的话我们可以把事件处理器添加到一个元素上,等待事件从它的子级元素里冒泡上来,并且可以很方便地判断出这个事件是从哪个元素开始的

<html xmlns="http://www.w3.org/1999/xhtml">
<head>
	<title>冒泡</title>
	<script src="script/jquery-1.11.0.min.js" type="text/javascript"></script>
	<script type="text/javascript">
		$(function () {
			$("div li").click(function (e) {
				alert("我是li"); return false;
			})
			$("div ul").click(function (e) { //这个e其实就是event 是一个事件的对象
				alert("我是ul"); e.stopPropagation(); //e.stopPropagation();就是阻止冒泡,如果不写这句,在弹出 “我是li”后就会弹出“我是ul”,然后就会弹出“我是div”。在这里添加了e.stopPropagation();之后,“我是div”就不会弹出来了。因为已经被阻止了。其实这句也可也用 return false来替代
			})
			$("div").click(function (e) {
				alert("我是div"); 
			})
		})
	</script>
</head>
<body>
<div>
	<ul>
	   <!-- li在ul里,ul在div中,只要点击了li,也就是点击了ul,也就是点击了div。在上面的函数中,先弹出 “我是li”然后弹出“我是ul”,最后弹出“我是div” 一层一层的冒泡,而阻止冒泡的方式就是调用 事件的对象来调用stopPropagation()方法。这个事件的对象就是函数的参数 e 这个e的名字可以随便取-->
		<li>请点击我</li>  
	</ul>
</div>
</body>
</html>

阻止默认行为和冒泡

标签:链接   default   函数   tty   讲解   对象   turn   ams   dom   

原文地址:http://www.cnblogs.com/handsomeboyyyyyy/p/6852621.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!