jQuery中$.fn的用法樣本介紹

來源:互聯網
上載者:User

$.fn是指jquery的命名空間,加上fn上的方法及屬性,會對jquery執行個體每一個有效。
如擴充$.fn.abc(),即$.fn.abc()是對jquery擴充了一個abc方法,那麼後面你的每一個jquery執行個體都可以引用這個方法了.
那麼你可以這樣子:$("#div").abc();

jQuery為開發外掛程式提拱了兩個方法,分別是:

jQuery.extend(object);為擴充jQuery類本身.為類添加新的方法。
jQuery.fn.extend(object);給jQuery對象添加方法。

fn是什麼東西呢。查看jQuery代碼,就不難發現。
複製代碼 代碼如下:
jQuery.fn = jQuery.prototype ={
   init: function( selector, context ){//.... 
   //......
};

原來 jQuery.fn =jQuery.prototype.對prototype肯定不會陌生啦。
jQuery便是一個封裝得非常好的類,比如我們用語句 $("#btn1") 會產生一個 jQuery類的執行個體。

jQuery.extend(object); 為jQuery類添加添加類方法,可以理解為添加靜態方法。如:
複製代碼 代碼如下:
$.extend({
  add:function(a,b){returna+b;}
});

便為 jQuery 添加一個為add 的 “靜態方法”,之後便可以在引入 jQuery 的地方,使用這個方法了,
$.add(3,4); //return 7

jQuery.fn.extend(object);對jQuery.prototype進得擴充,就是為jQuery類添加“成員函數”。jQuery類的執行個體可以使用這個“成員函數”。
比如我們要開發一個外掛程式,做一個特殊的編輯框,當它被點擊時,便alert當前編輯框裡的內容。可以這麼做:

jQuery代碼
複製代碼 代碼如下:
$.fn.extend({

alertWhileClick:function(){

$(this).click(function(){

alert($(this).val());
});
}
});

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.