Latest web development tutorials

jQuery UI 為什麼使用部件庫

編寫jQuery插件與向jQuery.prototype (通常顯示為$.fn )添加方法一樣簡單,且需要遵循一些簡單的規則,比如返回this 。 所以為什麼會存在部件庫(Widget Factory)?

在本章節中,我們將講解部件庫(Widget Factory)的好處​​,並了解何時使用它,以及為什麼要使用它。

無狀態vs. 有狀態插件

大多數jQuery 插件是無狀態的,它們執行一些動作即完成了它們的任務。 例如,如果您使用.text( "hello" )設置元素的文本,沒有安裝階段,結果都是一樣的。 對於這種類型的插件,它只是擴展了jQuery 的原型。

然而,一些插件是有狀態的,它們有全生命週期、維持狀態以及對變化的反應。 這些插件需要大量專門的代碼來初始化和狀態管理(有時是銷毀)。 這就導致出現了用於創建有狀態插件的模板。 更糟糕的是,每個插件的作者按照不同的方式進行管理插件的生命週期和狀態,這就導致了不同的插件有不同的API 樣式。 部件庫(Widget Factory)旨在解決這些問題,它移除了模板,並為插件創建了一個一致的API。

一致的API

部件庫(Widget Factory)定義瞭如何創建和銷毀小部件,獲取和設置選項,調用方法,以及監聽小部件觸發的事件。 通過使用部件庫(Widget Factory)來創建有狀態的插件,會自動符合定義的標準,讓新用戶更容易使用您的插件。 另外,部件庫(Widget Factory)還能實現定義接口的功能。 如果您對部件庫(Widget Factory)提供的API還不熟悉,請查看如何使用部件庫(Widget Factory)

在初始化時設置選項

當您創建一個接受選項的插件時,您應該為盡可能多的選項定義defaults。 然後在初始化時,把用戶提供的選項與defaults 進行合併。 您也可以暴露defaults,這樣用戶就可以更改默認值。 在jQuery 插件中,一個常用的模式如下所示:

$.fn.plugin = function( options ) {
    options = $.extend( {}, $.fn.plugin.defaults, options );
    // Plugin logic goes here.
};
 
$.fn.plugin.defaults = {
    param1: "foo",
    param2: "bar",
    param3: "baz"
};

部件庫(Widget Factory)也提供了這個功能,並在這上面做了改進。 使用部件庫(Widget Factory)之後,它將如下所示。

$.widget( "ns.plugin", {
 
    // Default options.
    options: {
        param1: "foo",
        param2: "bar",
        param3: "baz"
    },
 
    _create: function() {
        // Options are already merged and stored in this.options
        // Plugin logic goes here.
    }
 
});