js阻止事件追加的具体实现
有些时候可以使用 e.stopPropagation(); e.preventDefault();来阻止事件冒泡,和默认事件的执行。但不能阻止事件的追加。
什么情况下要阻止事件的追加呢?
比如:
点击“结账”,这样的操作时,结账本身有自己的事件,但结账前要判断是否登录。
我们可能会这样写:
Js代码
if(isLogin){ //判断是否登录
console.log("没有登录")
}else{
//结账相关代码
}
如果点击“我的主页”也有登录判断
登录判断代码
if(isLogin){ //判断是否登录
console.log("没有登录")
}else{
//个人中心
}
如果还有更多的登录判断。是不是就会有更多像上面的代码呢?后来我发现stopImmediatePropagation()这个方法, 阻止事件追加。上面的问题就不是问题了。
重要:.确保登录判断事件是第一个绑定的事件。
Demo代码
<!DOCTYPE html>
<html>
<head lang="en">
<meta charset="UTF-8">
<title>demo</title>
<script src="http://lib.sinaapp.com/js/jquery/1.7.2/jquery.min.js"></script>
</head>
<body>
<a href="#" class="bill isLogin">结账 </a>
<ul>
<li class="a1 isLogin">加入收藏夹</li>
<li class="a2 isLogin">他人支付</li>
<li class="a3">加入购入车</li>
<li class="a4 isLogin">我的主页</li>
</ul>
<script>
//最先绑定
$(".isLogin").on("click", function (e) {
if(true){ //登录判断
alert("没有登录");
e.stopImmediatePropagation();
}
return false;
});
$(".bill").on("click",function(){
alert("结账相关内容!");
});
$(".a1").on("click",function(){
alert("a1");
});
$(".a2").on("click",function(){
alert("a2");
});
$(".a3").on("click",function(){
alert("已加入购物车");
});
$(".a4").on("click",function(){
alert("有登录判断");
});
</script>
</body>
</html>
其实,jquery给我们提供了查看事件的方法$._data($('.isLogin').get(0)),打开firebug,在控制台输入。
Js代码
$._data($('.isLogin').get(0))
会看到如下:
Js代码
Object { events={...}, handle=function()}
点击可以看到事件数组,方便查看元素上绑定了什么样的事件。
相关文章
How to Auto Include a Javascript File
How to Auto Include a Javascript File...2007-02-02常见的浏览器存储方式(cookie、localStorage、sessionStorage)
今天我们从前端的角度了解一下浏览器存储,我们常见且常用的存储方式主要由两种:cookie、webStorage(localStorage和sessionStorage)。本文通过实例代码给大家介绍的非常详细,具有一定的参考借鉴价值,需要的朋友参考下吧2019-05-05前端插件之Bootstrap Dual Listbox使用教程
这篇文章主要介绍了前端插件之Bootstrap Dual Listbox使用教程,本文给大家介绍的非常详细,具有一定的参考借鉴价值 ,需要的朋友可以参考下2019-07-07
最新评论