jQuery.proxy( function, context )返回: Function版本已弃用: 3.3
描述: 接受一个函数,并返回一个新函数,该新函数将始终具有特定的上下文。
-
版本添加: 1.4jQuery.proxy( function, context )
-
function类型:Function()要更改其上下文的函数。
-
context (上下文)类型: PlainObject函数应设置其上下文(
this)的对象。
-
-
版本添加: 1.4jQuery.proxy( context, name )
-
context (上下文)类型: PlainObject函数应设置其上下文的对象。
-
name类型: 字符串要更改其上下文的函数的名称(应该是
context对象的属性)。
-
-
版本添加: 1.6jQuery.proxy( function, context [, additionalArguments ] )
-
function类型:Function()要更改其上下文的函数。
-
context (上下文)类型: PlainObject函数应设置其上下文(
this)的对象。 -
additionalArguments类型: Anything要传递给
function参数中引用的函数的任何数量的参数。
-
-
版本添加: 1.6jQuery.proxy( context, name [, additionalArguments ] )
-
context (上下文)类型: PlainObject函数应设置其上下文的对象。
-
name类型: 字符串要更改其上下文的函数的名称(应该是
context对象的属性)。 -
additionalArguments类型: Anything要传递给
name参数中命名的函数的任何数量的参数。
-
注意:此 API 已在 jQuery 3.3 中弃用;请改用原生的 Function.prototype.bind 方法。
此方法对于将事件处理程序附加到上下文指向其他对象的元素最为有用。此外,jQuery 确保即使您绑定了从 jQuery.proxy() 返回的函数,当传递原始函数时,它仍然会解除绑定正确的函数。
但是,请注意,jQuery 的事件绑定子系统为每个事件处理函数分配一个唯一的 ID,以便在将其用于解除绑定函数时进行跟踪。jQuery.proxy() 表示的函数被事件子系统视为单个函数,即使它用于绑定不同的上下文。为避免解除绑定错误的事件处理程序,请在绑定和解除绑定时使用唯一的事件命名空间(例如,"click.myproxy1"),而不是在解除绑定时指定代理函数。
从 jQuery 1.6 开始,可以向 $.proxy() 提供任意数量的附加参数,并且这些参数将被传递给上下文将被更改的函数。
从 jQuery 1.9 开始,当 context 是 null 或 undefined 时,代理函数将使用调用代理的相同 this 对象来调用。这允许 $.proxy() 用于部分应用函数的参数而不更改上下文。
示例
示例 1
使用“函数,上下文”签名更改绑定到点击处理程序的函数的上下文。首次点击后解除绑定第一个处理程序。
|
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
|
|
演示
示例 2
使用“上下文,函数名称”签名强制函数的上下文。首次点击后解除绑定处理程序。
|
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
|
|
演示
示例 3
更改绑定到点击处理程序的函数的上下文,
|
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
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
|
|