其實只有兩種使用方式,只不過每一種又細分是否傳參。
先給一段HTML,後面會用來測試:
jquery.proxy(function, context);
#使用context作為function運行上下文(即this)
2,jQuery.proxy(function, context [, additionalArguments]);
將參數傳遞參數給function
#使用場景:click時,執行function,在給定的context裡,同時傳遞兩個參數,如果需要event,則可以作為function第三個參數。
注意:function執行的環境如果不適用proxy,則context會是目前點擊
物件,現在指定了其他的上下文,已經跟目前點擊物件沒有一點關係了。
var me = { /* I'm a dog */ type: "dog", /* Note that event comes *after* one and two */ test: function(one, two, event) { $("#log") /* `one` 是第一个附加参数,与对象`you`对应 */ .append( "<h3>Hello " + one.type + ":</h3>" ) /* `two` 是第二个附加参数,与对象`they`对应 */ .append( "and they are " + two.type + ".<br>" ) /* `this` 是上下文,与普通对象`me`对应 */ .append( "I am a " + this.type + ", " ) /* 事件类型是点击"click" */ .append( "Thanks for " + event.type + "ing " ) /* `event.target`是被点击元素,类型是按钮button */ .append( "the " + event.target.type + "." ); } }; var you = { type: "cat" }; var they = { type: "fish" }; /* 一共4个参数:第一个是function,第二个是context,第三、四是参数 */ var proxy = $.proxy( me.test, me, you, they ); $("#test").on( "click", proxy ); /* 运行结果: Hello cat: and they are fish. I am a dog, Thanks for clicking the submit. */
var obj = { name: "John", test: function() { console.log(this); $("#log").append( this.name ); $("#test").off("click", obj.test); } }; $("#test").on( "click", jQuery.proxy( obj, "test" ) );//在click时执行,但又 不是click的上下文
以上是jquery.proxy的四種使用情境的實例詳解的詳細內容。更多資訊請關注PHP中文網其他相關文章!