有些时候可以使用 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="/UploadFiles/2021-04-02/jquery.min.js"> </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()}

点击可以看到事件数组,方便查看元素上绑定了什么样的事件。

华山资源网 Design By www.eoogi.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站资源来自互联网收集,仅供用于学习和交流,请遵循相关法律法规,本站一切资源不代表本站立场,如有侵权、后门、不妥请联系本站删除!
华山资源网 Design By www.eoogi.com

稳了!魔兽国服回归的3条重磅消息!官宣时间再确认!

昨天有一位朋友在大神群里分享,自己亚服账号被封号之后居然弹出了国服的封号信息对话框。

这里面让他访问的是一个国服的战网网址,com.cn和后面的zh都非常明白地表明这就是国服战网。

而他在复制这个网址并且进行登录之后,确实是网易的网址,也就是我们熟悉的停服之后国服发布的暴雪游戏产品运营到期开放退款的说明。这是一件比较奇怪的事情,因为以前都没有出现这样的情况,现在突然提示跳转到国服战网的网址,是不是说明了简体中文客户端已经开始进行更新了呢?