你所忽视的jQuery on事件 Event.namespace 添加命名空间

 
  • 1
  • 2

namespace属性用于返回触发该事件时所指定的命名空间。

当需要为同一个元素、同一种事件类型绑定多个事件处理函数时,一般情况下,触发某个事件,就会触发执行与之对应的所有事件处理函数;解除某种类型的事件绑定,就会解除该事件类型绑定的所有事件处理函数。

jQuery中的事件函数可以在绑定事件处理函数时,为每个事件类型定义一个或多个命名空间。使用命名空间,我们就可以只触发执行指定命名空间下的事件处理函数,或者只移除指定命名空间下绑定的事件处理函数。

该属性属于jQuery的Event对象(实例)。
  • 1
  • 2

语法

jQuery 1.4.3 新增该属性。

eventObject.namespace
  • 1
  • 2
  • 3
  • 4

返回值

namespace属性的返回值是String类型,返回触发该事件时所指定的命名空间。

如果触发事件时没有指定命名空间,则返回空字符串("")。
  • 1
  • 2
  • 3
  • 4

示例&说明

jQuery中事件类型的命名空间有点类似于类名选择器(.className)。
  • 1
  • 2

在绑定事件时,可以在事件类型后定义一个或多个命名空间;在触发事件或移除事件时,可以只触发或移除包含指定命名空间的事件处理函数。

<p>CodePlayer</p>


<script type="text/javascript">
// 事件处理函数,弹出警告框并显示命名空间
function handler( event ){
    alert( event.namespace );
}

var $p = $("p");

// A:为所有p元素绑定click事件,定义在abc和foo两个命名空间下
$p.on( "click.a.foo", handler );

// B:为所有p元素绑定click事件,定义在test命名空间下
$p.on( "click.test", handler );

// C:为所有p元素绑定click事件,定义在new和foo两个命名空间下
$p.on( "click.new.foo", handler );


// 执行所有的click事件处理函数,不限定命名空间 (触发A、B、C)
$p.trigger( "click" ); // ""


// 执行定义在abc命名空间下的click事件处理函数 (触发A)
$p.trigger( "click.abc" ); // "abc"
// 执行定义在foo命名空间下的click事件处理函数 (触发A和C)
$p.trigger( "click.foo" ); // "foo"
// 执行同时定义在foo和abc命名空间下的click事件处理函数 (触发A)
$p.trigger( "click.foo.abc" ); // "abc.foo"
// 执行定义在test命名空间下的click事件处理函数 (触发C)
$p.trigger( "click.test" ); // "test"


// 移除所有定义在foo命名空间下的click事件处理函数
$p.off( "click.foo" );
</script>
  • 1
  • 2
  • 3
  • 4
  • 5
  • 6
  • 7
  • 8
  • 9
  • 10
  • 11
  • 12
  • 13
  • 14
  • 15
  • 16
  • 17
  • 18
  • 19
  • 20
  • 21
  • 22
  • 23
  • 24
  • 25
  • 26
  • 27
  • 28
  • 29
  • 30
  • 31
  • 32
  • 33
  • 34
  • 35
  • 36
  • 37
  • 38

有没有感觉清醒了呢~~

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值