jQuery.proxy()代理、回调方法

jQuery.proxy(),接受一个函数,然后返回一个新函数,并且这个新函数始终保持了特定的上下文(context )语境。

·         jQuery.proxy( function, context )

function将要改变上下文语境的函数。

context函数的上下文语境(`this`)会被设置成这个 object 对象。

·         jQuery.proxy( context, name )

context函数的上下文语境会被设置成这个 object 对象。

name将要改变上下文语境的函数名(这个函数必须是前一个参数 ‘context’ 对象的属性)

这个方法通常在向一个元素上附加事件处理函数时,上下文语境实际是指向另一个对象的情况下使用。

另外,jQuery 能够确保即使你绑定的函数是经过 jQuery.proxy() 处理过的函数,你依然可以用原先的函数来正确地取消绑定。

看一下官方的例子:

01

var obj = {

02

name: "John",

 

03

test: function() {

04

alert( this.name );

 

05

$("#test").unbind("click", obj.test);

06

}

 

07

};

08

 

 

09

$("#test").click( jQuery.proxy( obj, "test" ) );

10

 

 

11

// 以下代码跟上面那句是等价的:

12

// $("#test").click( jQuery.proxy( obj.test, obj ) );

 

13

 

14

// 可以与单独执行下面这句做个比较。

 

15

// $("#test").click( obj.test );

再看一下jquery.proxy的源码:

01

 

04

jQuery.proxy = function( fn, proxy, thisObject ) {

 

05

    if ( arguments.length === 2 ) {

06

        // jQuery.proxy(context, name);

 

07

        if ( typeof proxy === "string" ) {

08

            thisObject = fn;

 

09

            fn = thisObject[ proxy ];

10

            proxy = undefined;

 

11

 

12

            

 

17

        }

18

        // jQuery.proxy(name, context);

 

19

        else if ( proxy && !jQuery.isFunction( proxy ) ) {

20

            thisObject = proxy;

 

21

            proxy = undefined;

22

        }

 

23

    }

24

    if ( !proxy && fn ) {

 

25

        

26

        proxy = function() {

 

27

            return fn.apply( thisObject || this, arguments );

28

        };

 

29

    }

30

    // Set the guid of unique handler to the same of original handler, so it can be removed

 

31

    if ( fn ) {

32

        proxy.guid = fn.guid = fn.guid || proxy.guid || jQuery.guid++;

 

33

    }

34

    // So proxy can be declared as an argument

 

35

    return proxy;

36

}

其实就是平常使用的的callapply,大部分的时候作为回调使用。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: requests.exceptions.ProxyError 是 Python 中 requests 库中的一种异常,表示在使用代理服务器请求时发生了错误。这可能是由于代理服务器无法连接,或者请求被代理服务器拒绝等原因导致的。 ### 回答2: requests.exceptions.ProxyError是requests库中的一个异常类,用于表示由于代理问题而导致的请求错误。 当使用requests库发送请求时,可以选择使用代理服务器来进行请求。但是在使用代理服务器时,可能会出现一些问题,导致请求无法成功,此时就会抛出ProxyError异常。 常见的ProxyError异常的原因包括: 1. 代理服务器连接超时:在请求过程中,连接到代理服务器的连接超时,可能是由于代理服务器网络问题造成的。 2. 代理服务器无法连接目标服务器:代理服务器无法建立与目标服务器的连接,可能是目标服务器故障或网络设置问题导致的。 3. 代理服务器认证失败:如果代理服务器进行了认证,但提供的用户名和密码不正确,则会导致认证失败。 在遇到ProxyError异常时,可以尝试以下解决方法: 1. 检查代理服务器设置:确保代理服务器的设置是正确的,包括代理地址、端口和认证信息等。 2. 检查网络连接:确保本地网络连接正常,能够正常访问互联网,以及能够正常连接到代理服务器。 3. 更换代理服务器:如果某个代理服务器无法正常工作,可以尝试使用其他可用的代理服务器。 4. 联系代理服务器管理员:如果尝试了以上方法仍无法解决问题,可以联系代理服务器管理员寻求解决办法。 总之,requests.exceptions.ProxyError是requests库中的一个异常类,表示由于代理问题造成的请求错误。在遇到该异常时,需要检查代理设置、网络连接以及代理服务器状态,并尝试解决问题。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值