模板一:javascript
//在頭部添加分號(;)是爲了不js壓縮後和其它代碼不規範的插件(末尾沒有分號)帶來的影響。 //(function(){})();表明定義一個匿名方法,而後執行此方法 ; (function ($) { //插件內部 私有方法 function t1() { console.debug(1); }; //插件內部 私有方法,和t1等效 var t2 = function () { console.debug(2); } //插件 公共方法,是全局方法,和window.t3 等效,通常不要在插件中出現此類用法 t3 = function () { console.debug(3); } //定義一個 全局變量 插件名稱爲 myDal; 外部使用myDal.t4();myDal.t5('hello'); //若是是要開發jquery插件,將window換成$便可,外部使用$.myDal.t4();$.myDal.t5('hello'); window.myDal = { t4: function () { console.debug(4); }, t5: function (txt) { console.debug(txt); } }; //擴展 插件myDal 內部方法,使用 myDal.t6(); //若是是jquery插件,需以下擴展 $.myDal.t6 = function(){....}; myDal.t6 = function () { console.debug(6); }; })(jQuery);
模板二(支持AMD規範):css
AMD規範介紹參考 http://www.ruanyifeng.com/blog/2012/10/asynchronous_module_definition.html
html
//在頭部添加分號(;)是爲了不js壓縮後和其它代碼不規範的插件(末尾沒有分號)帶來的影響。 ; (function (factory) { if (typeof define === "function" && define.amd) { // 使用AMD規範模式 define(["jquery"], factory); } else { // 使用全局模式 factory(jQuery); } }(function ($) { //插件內部 私有方法 function t1() { console.debug(1); }; //插件內部 私有方法,和t1等效 var t2 = function () { console.debug(2); } //插件 公共方法,是全局方法,和window.t3 等效,通常不要在插件中出現此類用法 t3 = function () { console.debug(3); } //定義一個 全局變量 插件名稱爲 myDal; 外部使用myDal.t4();myDal.t5('hello'); //若是是要開發jquery插件,將window換成$便可,外部使用$.myDal.t4();$.myDal.t5('hello'); window.myDal = { t4: function () { console.debug(4); }, t5: function (txt) { console.debug(txt); } }; //擴展 插件myDal 內部方法,使用 myDal.t6(); //若是是jquery插件,需以下擴展 $.myDal.t6 = function(){....}; myDal.t6 = function () { console.debug(6); }; }));
jquery.fn.xxx擴展插件java
參考:jquery
http://www.css88.com/archives/4821git
http://www.cnblogs.com/damonlan/archive/2012/04/06/2434460.html
github
相關文章推薦jquery插件
http://justineo.github.io/singles/writing-modular-js/
async
http://www.css88.com/archives/4826
wordpress
http://www.zhangxinxu.com/wordpress/?cat=5