您好,登錄后才能下訂單哦!
使用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();
免責(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)容。