• 技术文章 >web前端 >js教程

    jquery之 off()方法

    巴扎黑巴扎黑2017-06-30 13:54:40原创766
    off()函数用于移除元素上绑定的一个或多个事件的事件处理函数

    off()函数主要用于解除由on()函数绑定的事件处理函数。

    该函数属于jQuery对象(实例)。

    语法

    jQuery 1.7 新增该函数。其主要有以下两种形式的用法:

    用法一

    jQueryObject.off( [ events [, selector ] [, handler ] ] )

    用法二

    jQueryObject.off( eventsMap [, selector ] )

    参数

    参数描述
    events可选/String类型一个或多个用空格分隔的事件类型和可选的命名空间,例如"click"、"focus click"、"keydown.myPlugin"。
    eventsMapObject类型一个Object对象,其每个属性对应事件类型和可选的命名空间(参数events),属性值对应绑定的事件处理函数(参数handler)。
    selector可选/String类型一个jQuery选择器,用于指定哪些后代元素可以触发绑定的事件。如果该参数为null或被省略,则表示当前元素自身绑定事件(实际触发者也可能是后代元素,只要事件流能到达当前元素即可)。
    handler可选/Function类型指定的事件处理函数。

    off()函数将会移除当前匹配元素上为后代元素selector绑定的events事件的事件处理函数handler

    如果省略参数selector,则移除为任何元素绑定的事件处理函数。

    参数selector必须与通过on()函数添加绑定时传入的选择器一致。

    如果省略参数handler,则移除指定元素指定事件类型上绑定的所有事件处理函数。

    如果省略了所有参数,则表示移除当前元素上为任何元素绑定的任何事件类型的任何事件处理函数。

    返回值

    off()函数的返回值jQuery类型,返回当前jQuery对象本身。

    实际上,off()函数的参数全是筛选条件,只有匹配所有参数条件的事件处理函数才会被移除。参数越多,限定条件就越多,被移除的范围就越小。

    示例&说明

    请参考下面这段初始HTML代码:

    <input id="btn1" type="button" value="点击1" />
    <input id="btn2" type="button" value="点击2" />
    <a id="a1" href="#">CodePlayer</a>

    首先,我们为上述button和<a>元素绑定事件,然后使用off()函数解除事件绑定,相应的代码如下:

    function btnClick1(){
    alert( this.value + "-1" );
    }

    function btnClick2(){
    alert( this.value + "-2" );
    }

    var $body = $("body");

    // 为所有button元素的click事件绑定事件处理函数btnClick1
    $body.on("click", ":button", btnClick1 );

    // 为所有button元素的click事件绑定事件处理函数btnClick2
    $body.on("click", ":button", btnClick2 );

    //为所有a元素绑定click、mouseover、mouseleave事件
    $body.on("click mouseover mouseleave", "a", function(event){
    if( event.type == "click" ){
    alert("点击事件");
    }else if( event.type == "mouseover" ){
    $(this).css("color", "red");
    }else{
    $(this).css("color", "blue");
    }
    });


    // 移除body元素为所有button元素的click事件绑定的事件处理函数btnClick2
    // 点击按钮,btnClick1照样执行
    $body.off("click", ":button", btnClick2);


    // 移除body元素为所有button元素的click事件绑定的所有事件处理函数(btnClick1和btnClick2)
    // 点击按钮,不会执行任何事件处理函数
    // $body.off("click", ":button");


    // 注意: $body.off("click", "#btn1"); 无法移除btn1的点击事件,off()函数指定的选择器必须与on()函数传入的选择器一致。


    // 移除body元素为所有元素(包括button和<a>元素)的click事件绑定的所有处理函数
    // 点击按钮或链接,都不会触发执行任何事件处理函数
    // $("body").off("click");


    // 移除body元素为所有元素的任何事件绑定的所有处理函数
    // 点击按钮,或点击链接或者鼠标移入/移出链接,都不会触发执行任何事件处理函数
    // $("body").off( );

    运行代码(其他代码请自行复制到演示页面运行)

    此外off()函数还可以只移除指定命名空间的事件绑定。

    var $btn1 = $("#btn1");

    $btn1.on("click.foo.bar", function(event){
    alert("click-1");
    });
    $btn1.on("click.test", function(event){
    alert("click-2");
    });
    $btn1.on("click.test.foo", function(event){
    alert("click-3");
    });

    $btn1.off("click.test"); // 移除click-2、click-3

    // $btn1.off("click.foo"); // 移除click-1、click-3

    // $btn1.off("click.foo.bar"); // 移除click-1

    // $btn1.off("click"); // 移除所有click事件处理函数(click-1、click-2、click-3)

    // $btn1.off(".foo"); // 移除所有包含命名空间foo的事件处理函数,不仅仅是click事件

    以上就是jquery之 off()方法的详细内容,更多请关注php中文网其它相关文章!

    声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn核实处理。
    专题推荐:jquery 方法
    上一篇:jquery之on()绑定事件和off()解除绑定事件 - 无信不立 下一篇:jQuery的.live()和.die() 使用介绍
    千万级数据并发解决方案

    相关文章推荐

    • JavaScript内置对象Math实例分享• angular学习之聊聊指令和管道• JavaScript知识点整理之获取元素和节点• 一文浅析angular中的组件模板• JavaScript学习理解之JSON(总结分享)
    1/1

    PHP中文网