您好,登錄后才能下訂單哦!
使用jquery時,函數中的this指向分為jquery對象和原生html對象。
所謂jquery對象就是繼承自jquery.fn的對象。
比如$("div")得到一個jquery對象,這個jquery對象封裝了頁面中所有的div元素,
通過$("div").length可以得到元素的個數;
通過$("div").bind(event, function(e){});可以給頁面中的元素注冊事件,
關鍵在于,它是通過給$("div")這個jquery對象封裝的每個div元素注冊事件來達到目的的,在這里function(e){}中的this指向原生div元素的js對象;
對于jquery.fn.extend({fun1:function{}, fun2:function{}})方法;
它是通過給所有jquery對象隱式鏈接的對象,即原型對象jquery.fn增加屬性來達到目的的,所以所有jquery對象都會繼承這里的屬性方法;
這樣以來fun1和fun2中的this指向變為了jquery對象了,而不是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();
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。