亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb

首頁 > 編程 > JavaScript > 正文

jQuery插件編寫步驟詳解

2019-11-20 09:48:46
字體:
來源:轉載
供稿:網友

本文實例講述了jQuery插件編寫步驟。分享給大家供大家參考,具體如下:

如今做web開發,jquery 幾乎是必不可少的,就連vs神器在2010版本開始將Jquery 及ui 內置web項目里了。至于使用jquery好處這里就不再贅述了,用過的都知道。今天我們來討論下jquery的插件機制,jquery有著成千上萬的第 三方插件,有時我們寫好了一個獨立的功能,也想將其與jquery結合起來,可以用jquery鏈式調用,這就要擴展jquery,寫成插件形式了,如下 面就是一個簡單擴展Jquery對象的demo:

//sample:擴展jquery對象的方法,bold()用于加粗字體。(function ($) {  $.fn.extend({    "bold": function () {      ///<summary>      /// 加粗字體      ///</summary>      return this.css({ fontWeight: "bold" });    }  });})(jQuery);

調用方式:

這是一個非常簡單的擴展。接下來我們一步步來解析上面的代碼。

一、jquery的插件機制

為了方便用戶創建插件,jquery提供了jQuery.extend()和jQuery.fn.extend()方法。

1. jQuery.extend() 方法有一個重載。

jQuery.extend(object) ,一個參數的用于擴展jQuery類本身,也就是用來在jQuery類/命名空間上增加新函數,或者叫靜態方法,例如jQuery內置的 ajax方法都是用jQuery.ajax()這樣調用的,有點像 "類名.方法名" 靜態方法的調用方式。下面我們也來寫個jQuery.extend(object)的例子:

//擴展jQuery對象本身jQuery.extend({  "minValue": function (a, b) {    ///<summary>    /// 比較兩個值,返回最小值    ///</summary>    return a < b ? a : b;  },  "maxValue": function (a, b) {    ///<summary>    /// 比較兩個值,返回最大值    ///</summary>    return a > b ? a : b;  }});//調用var i = 100; j = 101;var min_v = $.minValue(i, j); // min_v 等于 100var max_v = $.maxValue(i, j); // max_v 等于 101

重載版本:

jQuery.extend([deep], target, object1, [objectN])

用一個或多個其他對象來擴展一個對象,返回被擴展的對象。
如果不指定target,則給jQuery命名空間本身進行擴展。這有助于插件作者為jQuery增加新方法。
如果第一個參數設置為true,則jQuery返回一個深層次的副本,遞歸地復制找到的任何對象。否則的話,副本會與原對象共享結構。
未定義的屬性將不會被復制,然而從對象的原型繼承的屬性將會被復制。

參數:

   deep:       可選。如果設為true,則遞歸合并。
   target:     待修改對象。
   object1:   待合并到第一個對象的對象。
   objectN:   可選。待合并到第一個對象的對象。

示例1:

合并 settings 和 options,修改并返回 settings。

var settings = { validate: false, limit: 5, name: "foo" };var options = { validate: true, name: "bar" };jQuery.extend(settings, options);

結果:

settings == { validate: true, limit: 5, name: "bar" }

示例2:

合并 defaults 和 options, 不修改 defaults。

var empty = {};var defaults = { validate: false, limit: 5, name: "foo" };var options = { validate: true, name: "bar" };var settings = jQuery.extend(empty, defaults, options);

結果:

settings == { validate: true, limit: 5, name: "bar" }empty == { validate: true, limit: 5, name: "bar" }

這個重載的方法,我們一般用來在編寫插件時用自定義插件參數去覆蓋插件的默認參數。

jQuery.fn.extend(object)擴展 jQuery 元素集來提供新的方法(通常用來制作插件)。

首先我們來看fn 是什么東西呢。查看jQuery代碼,就不難發現。

jQuery.fn = jQuery.prototype = {  init: function( selector, context ) {.....};};

原來 jQuery.fn = jQuery.prototype,也就是jQuery對象的原型。那jQuery.fn.extend()方法就是擴展jQuery對象的原型方法。我 們知道擴展原型上的方法,就相當于為對象添加"成員方法",類的"成員方法"要類的對象才能調用,所以使用 jQuery.fn.extend(object)擴展的方法, jQuery類的實例可以使用這個"成員函數"。jQuery.fn.extend(object)和jQuery.extend(object)方法一 定要區分開來。

二、自執行的匿名函數/閉包

1. 什么是自執行的匿名函數?

它是指形如這樣的函數:

(function {// code})();

2. 疑問 為什么(function {// code})();可以被執行, 而function {// code}();卻會報錯?

3. 分析

(1). 首先, 要清楚兩者的區別:

(function {// code})是表達式, function {// code}是函數聲明.

(2). 其次, js"預編譯"的特點:

js在"預編譯"階段, 會解釋函數聲明, 但卻會忽略表式.

(3). 當js執行到function() {//code}();時, 由于function() {//code}在"預編譯"階段已經被解釋過, js會跳過function(){//code}, 試圖去執行();, 故會報錯;
當js執行到(function {// code})();時, 由于(function {// code})是表達式, js會去對它求解得到返回值, 由于返回值是一 個函數, 故而遇到();時, 便會被執行.
另外, 函數轉換為表達式的方法并不一定要靠分組操作符(),我們還可以用void操作符,~操作符,!操作符……

例如:

bootstrap 框架中的插件寫法:

!function($){//do something;}(jQuery);

(function($){//do something;})(jQuery);

是一回事。

匿名函數最大的用途是創建閉包(這是JavaScript語言的特性之一),并且還可以構建命名空間,以減少全局變量的使用。

例如:

var a=1;(function()(){  var a=100;})();alert(a); //彈出 1

三、一步一步封裝JQuery插件

接下來我們一起來寫個高亮的jqury插件

1.定一個閉包區域,防止插件"污染"

//閉包限定命名空間(function ($) {})(window.jQuery);

2.jQuery.fn.extend(object)擴展jquery 方法,制作插件

//閉包限定命名空間(function ($) {  $.fn.extend({    "highLight":function(options){      //do something    }  });})(window.jQuery);

3.給插件默認參數,實現 插件的功能

//閉包限定命名空間(function ($) {  $.fn.extend({    "highLight": function (options) {      var opts = $.extend({}, defaluts, options); //使用jQuery.extend 覆蓋插件默認參數      this.each(function () { //這里的this 就是 jQuery對象        //遍歷所有的要高亮的dom,當調用 highLight()插件的是一個集合的時候。        var $this = $(this); //獲取當前dom 的 jQuery對象,這里的this是當前循環的dom        //根據參數來設置 dom的樣式        $this.css({          backgroundColor: opts.background,          color: opts.foreground        });      });    }  });  //默認參數  var defaluts = {    foreground: 'red',    background: 'yellow'  };})(window.jQuery);

到這一步,高亮插件基本功能已經具備了。調用代碼如下:

$(function () {  $("p").highLight(); //調用自定義 高亮插件});

這里只能 直接調用,不能鏈式調用。我們知道jQuey是可以鏈式調用的,就是可以在一個jQuery對象上調用多個方法,如:

$('#id').css({marginTop:'100px'}).addAttr("title","測試");

但是我們上面的插件,就不能這樣鏈式調用了。比如:

$("p").highLight().css({marginTop:'100px'});

將會報找不到css方法,原因在與我的自定義插件在完成功能后,沒有將 jQuery對象給返回出來。接下來,return jQuery對象,讓我們的插件也支持鏈式調用。(其實很簡單,就是執行完我們插件代碼的時候將jQuery對像return 出來,和上面的代碼沒啥區別)

//閉包限定命名空間(function ($) {  $.fn.extend({    "highLight": function (options) {      var opts = $.extend({}, defaluts, options); //使用jQuery.extend 覆蓋插件默認參數      return this.each(function () { //這里的this 就是 jQuery對象。這里return 為了支持鏈式調用        //遍歷所有的要高亮的dom,當調用 highLight()插件的是一個集合的時候。        var $this = $(this); //獲取當前dom 的 jQuery對象,這里的this是當前循環的dom        //根據參數來設置 dom的樣式        $this.css({          backgroundColor: opts.background,          color: opts.foreground        });      });    }  });  //默認參數  var defaluts = {    foreground: 'red',    background: 'yellow'  };})(window.jQuery);

4.暴露公共方法 給別人來擴展你的插件(如果有需求的話)

比如的高亮插件有一個format方法來格式話高亮文本,則我們可將它寫成公共的,暴露給插件使用者,不同的使用著根據自己的需求來重寫該format方法,從而是高亮文本可以呈現不同的格式。

//公共的格式化 方法. 默認是加粗,用戶可以通過覆蓋該方法達到不同的格式化效果。$.fn.highLight.format = function (str) {  return "<strong>" + str + "</strong>";}

5.插件私有方法

有些時候,我們的插件需要一些私有方法,不能被外界訪問。例如 我們插件里面需要有個方法 來檢測用戶調用插件時傳入的參數是否符合規范。

6.其他的一些設置,如:為你的插件加入元數據插件的支持將使其變得更強大。

完整的高亮插件代碼如下:

//閉包限定命名空間(function ($) {  $.fn.extend({    "highLight": function (options) {      //檢測用戶傳進來的參數是否合法      if (!isValid(options))        return this;      var opts = $.extend({}, defaluts, options); //使用jQuery.extend 覆蓋插件默認參數      return this.each(function () { //這里的this 就是 jQuery對象。這里return 為了支持鏈式調用        //遍歷所有的要高亮的dom,當調用 highLight()插件的是一個集合的時候。        var $this = $(this); //獲取當前dom 的 jQuery對象,這里的this是當前循環的dom        //根據參數來設置 dom的樣式        $this.css({          backgroundColor: opts.background,          color: opts.foreground        });        //格式化高亮文本        var markup = $this.html();        markup = $.fn.highLight.format(markup);        $this.html(markup);      });    }  });  //默認參數  var defaluts = {    foreground: 'red',    background: 'yellow'  };  //公共的格式化 方法. 默認是加粗,用戶可以通過覆蓋該方法達到不同的格式化效果。  $.fn.highLight.format = function (str) {    return "<strong>" + str + "</strong>";  }  //私有方法,檢測參數是否合法  function isValid(options) {    return !options || (options && typeof options === "object") ? true : false;  }})(window.jQuery);

調用:

//調用//調用者覆蓋 插件暴露的共公方法$.fn.highLight.format = function (txt) {  return "<em>" + txt + "</em>"}$(function () {  $("p").highLight({ foreground: 'orange', background: '#ccc' }); //調用自定義 高亮插件});

更多關于jQuery相關內容感興趣的讀者可查看本站專題:《jQuery常用插件及用法總結》、《jquery中Ajax用法總結》、《jQuery表格(table)操作技巧匯總》、《jQuery拖拽特效與技巧總結》、《jQuery擴展技巧總結》、《jQuery常見經典特效匯總》、《jQuery動畫與特效用法總結》及《jquery選擇器用法總結

希望本文所述對大家jQuery程序設計有所幫助。

發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
亚洲香蕉成人av网站在线观看_欧美精品成人91久久久久久久_久久久久久久久久久亚洲_热久久视久久精品18亚洲精品_国产精自产拍久久久久久_亚洲色图国产精品_91精品国产网站_中文字幕欧美日韩精品_国产精品久久久久久亚洲调教_国产精品久久一区_性夜试看影院91社区_97在线观看视频国产_68精品久久久久久欧美_欧美精品在线观看_国产精品一区二区久久精品_欧美老女人bb
国产成人综合精品| 91久久精品日日躁夜夜躁国产| 91国内精品久久| 久久精品99久久久久久久久| 国产一区二区三区视频| 亚洲石原莉奈一区二区在线观看| 亚洲国产精品久久久久秋霞蜜臀| 国产精品国产自产拍高清av水多| 亚洲最新av在线| 亚洲人成自拍网站| 欧美华人在线视频| 91精品国产高清自在线| 亚洲人高潮女人毛茸茸| 一区二区成人av| 亚洲午夜女主播在线直播| 久久久久久久国产精品视频| 日韩视频免费在线| 日韩在线一区二区三区免费视频| 91精品国产91久久久| 日本不卡高字幕在线2019| 91精品久久久久久久久| 久久久噜噜噜久久中文字免| 大伊人狠狠躁夜夜躁av一区| 亚洲视频在线看| 超薄丝袜一区二区| 久久精品亚洲一区| 国产精品亚洲自拍| 亚洲国产天堂久久综合| 正在播放亚洲1区| 日韩一二三在线视频播| 久久久久久久久国产精品| 国产精品色悠悠| 欧美精品久久久久久久久| 久久大大胆人体| 日本午夜精品理论片a级appf发布| 在线日韩第一页| 美乳少妇欧美精品| 在线看欧美日韩| 久久精品中文字幕免费mv| 中文字幕欧美日韩在线| 久久久精品视频在线观看| 久久精品夜夜夜夜夜久久| 国产精品99免视看9| 欧美精品手机在线| 美日韩精品免费观看视频| 欧美亚洲成人免费| 日韩av电影在线免费播放| 亚洲最新av网址| 韩国国内大量揄拍精品视频| 国产精品久久电影观看| 久久天天躁狠狠躁夜夜av| 69影院欧美专区视频| 久久久av电影| 亚洲毛片一区二区| 国产精品综合久久久| 亚洲美女自拍视频| 国内精品久久久久久中文字幕| 97激碰免费视频| 国产精品一二三在线| 亚洲福利在线视频| 国产成人精品久久亚洲高清不卡| 国产成人精品久久| 成人深夜直播免费观看| 日韩精品免费视频| 亚洲天堂av图片| 亚洲欧美制服丝袜| 色偷偷av亚洲男人的天堂| 中文字幕亚洲在线| 成人久久久久久久| 亚洲免费影视第一页| 欧美日韩免费在线| 国产z一区二区三区| 日韩最新在线视频| 91精品中文在线| 精品国产一区久久久| 精品亚洲夜色av98在线观看| 国产a级全部精品| 久久精品人人做人人爽| 欧美成人第一页| 欧美成人网在线| 日韩精品中文字幕视频在线| 成人做爰www免费看视频网站| 久久精品99久久久久久久久| 国产精品日韩欧美大师| 亚洲大尺度美女在线| 538国产精品一区二区免费视频| 亚洲一区二区三区四区在线播放| 成人免费xxxxx在线观看| 国产精品视频专区| 欧洲精品毛片网站| 国产亚洲欧美aaaa| 91精品中文在线| 欧美床上激情在线观看| 国产91精品最新在线播放| 国产精品极品尤物在线观看| 欧美床上激情在线观看| 亚洲资源在线看| 亚洲а∨天堂久久精品9966| 一区二区三区在线播放欧美| 高清在线视频日韩欧美| 精品国内产的精品视频在线观看| 日韩精品免费观看| 97久久超碰福利国产精品…| 久久免费视频网| 欧美精品激情在线观看| 欧美高清视频在线观看| 一区二区三区日韩在线| 亚洲精品网站在线播放gif| 国产精品精品久久久| 久久的精品视频| 亚洲福利视频网| 中文字幕日韩av电影| 国产精品电影久久久久电影网| 日韩av在线影院| 欧美日韩激情视频| 大荫蒂欧美视频另类xxxx| 欧美大尺度在线观看| 国产日产欧美精品| 日本国产一区二区三区| 欧美人与性动交| 一区二区三区 在线观看视| 亚洲美女激情视频| 8x拔播拔播x8国产精品| 亚洲xxxx妇黄裸体| 欧美激情视频网| 欧美日韩国产123| 欧美—级高清免费播放| 亚洲理论电影网| 精品人伦一区二区三区蜜桃免费| 亚洲国产日韩欧美在线图片| 亚洲欧美国产精品久久久久久久| 亚洲激情自拍图| 国产精品视频公开费视频| 欧美精品手机在线| 欧美刺激性大交免费视频| 国产成人精品一区二区| 国产精品高清在线| 亚洲福利视频在线| 伊人久久久久久久久久久久久| 中文字幕精品—区二区| 日韩精品极品在线观看| 亚洲精品一区久久久久久| 欧美日韩亚洲激情| 久久精品国产久精国产思思| 欧美在线播放视频| 久久99国产精品自在自在app| 欧美性猛交xxxx久久久| 国产精品永久免费观看| 欧美俄罗斯性视频| 国产精品aaa| 国产精品在线看| 国产精品美女网站| 欧美激情精品久久久久久变态| 久久精彩免费视频| 在线播放日韩av| 91夜夜未满十八勿入爽爽影院| 黑人巨大精品欧美一区二区一视频| 青青草国产精品一区二区| 国产va免费精品高清在线观看| 国产精品www网站| 777777777亚洲妇女| 一区二区三区无码高清视频| 91久久精品日日躁夜夜躁国产| 国产啪精品视频网站|