一、解绑事件方法unbind()

  • 用什么方式绑定的事件,最好用对应的方式解绑事件
  • unbind("事件名字")括号里写上事件名字,就会解除这个事件
  • unbind()括号里没有参数就是解除全部事件
  • 对象.事件()这种方法添加的事件也可以使用unbind解除
    <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script>
<script>
$(function(){
//为div绑定事件
$("#btn1").click(function(){
$("#dv").bind("click",function(){
console.log("div第一次被点了!!!");
}).bind("click",function(){
console.log("div第二次被点了!!!");
}).bind("mouseenter",function(){
console.log("鼠标进入div了!!!");
}).bind("mouseleave",function(){
console.log("鼠标离开div了!!!");
});
});
//为div解绑单个事件,所有的点击事件都会被移除
$("#btn2").click(function(){
$("#dv").unbind("click");
});
//为div解绑所有的事件,div的所有事件都会被移除
$("#btn3").click(function(){
$("#dv").unbind();
});
});
</script>
<input type="button" value="绑定事件" id="btn1">
<input type="button" value="解绑事件单个" id="btn2">
<input type="button" value="解绑事件全部" id="btn3">
<div id="dv" style="width: 300px;height: 300px;border: 1px solid #000;"></div>

二、解绑事件方法undelegate()

    <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script>
<script>
$(function(){
//为div绑定事件,同时在div中创建添加一个p标签,并且绑定事件
$("#btn1").click(function(){
//div绑定事件
$("#dv").click(function(){
console.log("div被点了!!!");
}).mouseenter(function(){
console.log("鼠标进入到div了!!!");
}).mouseleave(function(){
console.log("鼠标离开div了!!!!");
});
//添加p,并绑定事件
$("<p>这个一个p</p>").appendTo($("#dv"));
$("#dv").delegate("p","click",function(){
console.log("p被点了!!!");
});
$("#dv").delegate("p","mouseenter",function(){
console.log("鼠标进入p了!!!");
});
$("#dv").delegate("p","mouseleave",function(){
console.log("鼠标离开p了!!!");
});
});
//解绑单个事件----解绑了p的点击事件,div的点击事件存在
$("#btn2").click(function(){
console.log("================");
$("#dv").undelegate("p","click");
});
//解绑多个事件------解绑了p的点击事件和鼠标进入事件.div的点击事件和鼠标进入事件存在
$("#btn3").click(function(){
console.log("================");
$("#dv").undelegate("p","click mouseenter");
});
//解绑全部事件-------解绑了p的全部事件,div的事件全部还存在
$("#btn4").click(function(){
console.log("================");
$("#dv").undelegate();
});
});
</script>
<input type="button" value="绑定事件" id="btn1">
<input type="button" value="解绑单个事件" id="btn2">
<input type="button" value="解绑多个事件" id="btn3">
<input type="button" value="解绑全部事件" id="btn4">
<div id="dv" style="width: 300px;height: 300px;border: 1px solid #000;"></div>

三、解绑事件方法off()

    <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"></script>
<script>
$(function () {
//为div绑定事件,同时在div中创建添加一个p标签,并且绑定事件
$("#btn1").click(function () {
//div绑定事件
$("#dv").click(function () {
console.log("div被点了!!!");
}).mouseenter(function () {
console.log("鼠标进入到div了!!!");
}).mouseleave(function () {
console.log("鼠标离开div了!!!!");
});
//添加p,并绑定事件
$("<p>这个一个p</p>").appendTo($("#dv"));
$("#dv").on("click","p",function () {
console.log("p被点了!!!");
});
$("#dv").on("mouseenter","p",function () {
console.log("鼠标进入p了!!!");
});
$("#dv").on("mouseleave","p",function () {
console.log("鼠标离开p了!!!");
});
});
//解绑子元素单个事件
$("#btn2").click(function () {
console.log("================");
$("#dv").off("click","p");
});
//解绑子元素多个事件
$("#btn3").click(function () {
console.log("================");
$("#dv").off("click mouseenter","p");
});
//解绑子元素全部事件
$("#btn4").click(function () {
console.log("================");
$("#dv").off("","p");
});
//解绑子元素和父元素单个事件
$("#btn5").click(function () {
console.log("================");
$("#dv").off("click");
});
//解绑子元素和父元素多个事件
$("#btn6").click(function () {
console.log("================");
$("#dv").off("click mouseenter");
});
//解绑子元素和父元素全部事件
$("#btn7").click(function () {
console.log("================");
$("#dv").off();
});
//补充:解绑div中所有的子元素的点击事件---不只是子元素p
$("#btn8").click(function () {
console.log("================");
$("#dv").off("click","**");
});
});
</script>
<input type="button" value="绑定事件" id="btn1">
<input type="button" value="解绑子单个事件" id="btn2">
<input type="button" value="解绑子多个事件" id="btn3">
<input type="button" value="解绑子全部事件" id="btn4">
<input type="button" value="解绑子和父单个事件" id="btn5">
<input type="button" value="解绑子和父多个事件" id="btn6">
<input type="button" value="解绑子和父全部事件" id="btn7">
<input type="button" value="补充" id="btn8">
<div id="dv" style="width: 300px;height: 300px;border: 1px solid #000;"></div>

jQuery相关方法8-----解绑事件的更多相关文章

  1. 从零开始学 Web 之 jQuery(六)为元素绑定多个相同事件,解绑事件

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... github:https://github.com/Daotin/Web 微信公众号:Web前端之巅 博客园:ht ...

  2. 【JQ】jq动态绑定事件.on()、解绑事件off()

    #JQ 绑定与解绑事件的方法的历史演变 1. jquery1.4 及之前的版本,由.click() 或 .bind()方法绑定的事件,不能适用脚本创建的新元素:即是说页面加载完成后,再动态创建的DOM ...

  3. 5月23日笔记-js绑定事件、解绑事件、复合事件

    each() $("p").each(function(i,ele){ //alert(ele.innerHTML); alert($("p:eq("+i+&q ...

  4. 从零开始学 Web 之 DOM(六)为元素绑定与解绑事件

    大家好,这里是「 从零开始学 Web 系列教程 」,并在下列地址同步更新...... +-------------------------------------------------------- ...

  5. JS---DOM---为元素解绑事件

    解绑事件 注意:用什么方式绑定事件, 就应该用对应的方式解绑事件 1.解绑事件 对象.on事件名字=事件处理函数--->绑定事件 对象.on事件名字=null;   //1 对象.on事件名字= ...

  6. jQuery事件之解绑事件

    语法: $(selector).unbind([eventType][,handler(eventObject)]); 返回值:jQuery 参数解释: eventTypey:类型:String以后包 ...

  7. jquery绑定事件,解绑事件

    unbind([type],[data]) 是 bind()的反向操作,从每一个匹配的元素中删除绑定的事件.如果没有参数,则删除所有绑定的事件.你可以将你用bind()注册的自定义事件取消绑定.如果提 ...

  8. jquery移除元素时会自动解绑事件

    .html() When .html() is used to set an element's content, any content that was in that element is co ...

  9. bind() unbind()绑定解绑事件

    .bind( eventType [, eventData], handler(eventObject)) 本文实例分析了JQuery中Bind()事件用法.分享给大家供大家参考.具体分析如下: .B ...

  10. jq的.off解绑事件

    .off( events [, selector ] [, handler ] ) 描述:移除一个事件处理函数 events 类型: String 一个或多个空格分隔的事件类型和可选的命名空间,或仅仅 ...

随机推荐

  1. h5开发微信公众号重定向到关注页面没有关注按钮 (微信你个坑)

    搜索微信公众号是这样的 微信公众号重定向到关注页面没有关注按钮 如何微信公众号重定向到关注页面没有关注按钮,请看上篇笔记 无解,微信一直在封这种通过链接跳转到公众号关注页面的方法.只有放个二维码提示长 ...

  2. Luogu5307 [COCI2019] Mobitel 【数论分块】【递推】

    题目分析: 对于向上取整我们总有,$\lceil \frac{\lceil \frac{n}{a} \rceil}{b} \rceil = \lceil \frac{n}{a*b} \rceil$这个 ...

  3. Sonya and Matrix Beauty CodeForces - 1080E (manacher)

    大意: 给定$nm$字符串矩阵. 若一个子矩形每一行重排后可以满足每行每列都是回文, 那么它为好矩形. 求所有好矩形个数. 一个矩形合法等价于每一行出现次数为奇数的最多只有一个字符, 并且对称的两行对 ...

  4. 在论坛中出现的比较难的sql问题:21(递归问题 检索某个节点下所有叶子节点)

    原文:在论坛中出现的比较难的sql问题:21(递归问题 检索某个节点下所有叶子节点) 最近,在论坛中,遇到了不少比较难的sql问题,虽然自己都能解决,但发现过几天后,就记不起来了,也忘记解决的方法了. ...

  5. c#使用GDI进行简单的绘图

    https://www.2cto.com/database/201805/749421.html https://zhidao.baidu.com/question/107832895.html pr ...

  6. ABP 基于DDD的.NET开发框架 学习(五)中使用DevExpress插件

    1.DevExpress安装 安装步骤1:开始安装 安装步骤2:选择需要安装的模块 安装步骤3:修改安装路径 安装步骤4:正在安装 安装步骤5:安装完成 2.Vs中设置 1)DevExtremeBun ...

  7. dev 从表处理

    从表列名,从表选中行和主表选中一样,var selectrow = detailView.GetRow(detailView.FocusedRowHandle) as obj; private voi ...

  8. 本地安装SQL Server 2017 Express和Microsoft SQL Server Management Studio 18.1

    sqlserver下载链接:https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 这个安装的是免费版的Express,当然也可 ...

  9. Python爬虫之BeautifulSoap的用法

    1. Beautiful Soup的简介 简单来说,Beautiful Soup是python的一个库,最主要的功能是从网页抓取数据.官方解释如下: Beautiful Soup提供一些简单的.pyt ...

  10. 自定义标签之inclusion_tag

    1.在当前app下创建templatetags文件夹 2.在templatetags文件夹下面创建自定义的mytag.py文件 3.在mytag.py文件中的代码 from django.templa ...