溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點(diǎn)擊 登錄注冊 即表示同意《億速云用戶服務(wù)條款》

探索jquery中this指向

發(fā)布時(shí)間:2020-06-23 05:52:45 來源:網(wǎng)絡(luò) 閱讀:478 作者:luoyuyou3 欄目:web開發(fā)

 使用jquery時(shí),函數(shù)中的this指向分為jquery對象和原生html對象。

所謂jquery對象就是繼承自jquery.fn的對象。

比如$("div")得到一個(gè)jquery對象,這個(gè)jquery對象封裝了頁面中所有的div元素,

通過$("div").length可以得到元素的個(gè)數(shù);

通過$("div").bind(event, function(e){});可以給頁面中的元素注冊事件,

關(guān)鍵在于,它是通過給$("div")這個(gè)jquery對象封裝的每個(gè)div元素注冊事件來達(dá)到目的的,在這里function(e){}中的this指向原生div元素的js對象;

對于jquery.fn.extend({fun1:function{}, fun2:function{}})方法;

它是通過給所有jquery對象隱式鏈接的對象,即原型對象jquery.fn增加屬性來達(dá)到目的的,所以所有jquery對象都會繼承這里的屬性方法;

這樣以來fun1和fun2中的this指向變?yōu)榱薺query對象了,而不是html對象,所以在fun1中可以直接寫this.each(function(){})....而不是通過$(this).each(function(){}),盡管后者也是可行

jQuery.fn.extend({

   myMethod: function(){

   $($($(this))).each(function(i){ $(this).click(function() 

       {alert($(this).html().trim() + i)})});

   } }

 

$(" div  p ").myMethod();

向AI問一下細(xì)節(jié)

免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。

AI