jQuery 外掛程式開發指南,jquery開發指南

來源:互聯網
上載者:User

jQuery 外掛程式開發指南,jquery開發指南

那麼首先我們來簡單的看一下最正統的 jQuery 外掛程式定義方式:

複製代碼 代碼如下:
(function ($) {    
$.fn.外掛程式名 = function (settings) {        
//預設參數        
var defaultSettings = {
 
        }         /* 合并預設參數和使用者自訂參數 */       
 
settings = $.extend(defaultSettings, settings);
 
return this.each(function () {             //代碼         });   //外掛程式在元素內多次出現
 
} })(jQuery);

 
先來看模板中的第一行代碼(當然我們要把這一行代碼的後半部分給揪出來一起看,不然第一行就完全無意義了):

複製代碼 代碼如下:
(function ($) {
 
})(jQuery);

 這行代碼其實是用於建立一個匿名函數。如果你對匿名函數和閉包不瞭解,將會對這種代碼非常疑惑,那麼強烈建議您閱讀【詳談JavaScript 匿名函數及閉包】這篇文章。

jQuery 的繼承方法 $.extend —— $.extend 在jQuery 外掛程式開發中有個很重要的作用,就是用於合并參數。

複製代碼 代碼如下:
$.fn.tip = function (settings) {    
var defaultSettings = {           
//顏色    
color: 'yellow',       
//延遲       
timeout: 200     }
 /* 合并預設參數和使用者自訂參數 */  
settings = $.extend(defaultSettings, settings);   
alert(settings.input); <br>}

 jQuery 外掛程式定義第二種方式:

複製代碼 代碼如下:
(function ($) {
    //外掛程式定義--更換名字
    $.fn.tabpanel = function (method) {
        var methods = $.fn.tabpanel.methods;
        if (methods[method]) {
            return methods[method].apply(this, Array.prototype.slice.call(arguments, 1));
        } else if (typeof method === 'object' || !method) {
            return methods.init.apply(this, arguments);
        } else {
 
        }
    }
    //支援的方法
    $.fn.tabpanel.methods =
    {
        //初始化
        init: function (p_options) {
            tabpanelBind(p_options, this);
        },
        add: function (p_options) {
            addTab(p_options, this);
            tabpanelBind(p_options, this);
            // debugger
        }    }
    function add(p_options) {
        var _defaults = {
            id: ""
        }
    <br>    //內部實現略.........<br>        return _index;
    }
<br>})(jQuery);<br><br>調用  $("#team").tabpanel('add',"");

好了,上面介紹的這2種開發方式都是最常用的,小夥伴們先好好學習下吧,後續我們再介紹的更深入些

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在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.