如何去定义一个jquery插件

 我来答
Baby_原來
推荐于2016-06-18 · TA获得超过3402个赞
知道大有可为答主
回答量:1535
采纳率:94%
帮助的人:505万
展开全部

扩展jquery的时候。最核心的方法是以下两种:

$.extend(object) 可以理解为jquery添加一个静态方法

$.fn.extend(object) 可以理解为jquery实例添加一个方法

 

$.extend(object)

例子:

/* $.extend 定义与调用* * * * * * * * * * * * * * * * * * * */
 
$.extend({ fun1: function () { alert("执行方法一"); } });//定义
 
$.fun1();//调用


$.fn.extentd(object)
/*****$.fn.extend 定义与调用* * * * * * * * * * * * * * * * * * * * * * * */ 

$.fn.extend({ fun2: function () { alert("执行方法2"); } }); 
$(this).fun2();
 
//等同于
 
$.fn.fun3 = function () { alert("执行方法三"); } 
$(this).fun3();

   

  

定义jquery插件的基本结构

 

1.  定义作用域:

为插件定义一个私有作用域。外界代码不能直接访问插件内部。插件内部代码不受外界干扰,也不会污染到全局变量。     

//step01 定义JQuery的作用域
(function ($) {
  
})(jQuery);

  

2. 为插件添加扩展方法:

//step01 定义JQuery的作用域
(function ($) {
    //step02 插件的扩展方法名称
    $.fn.easySlider = function (options) {
        
    }
})(jQuery);

 

3. 设置默认值:

//step01 定义JQuery的作用域
(function ($) {
    //step03-a 插件的默认值属性
  var defaults = {
      prevId: 'prevBtn',
    prevText: 'Previous',
    nextId: 'nextBtn',
    nextText: 'Next'
    //……
};

//step02 插件的扩展方法名称
$.fn.easySlider = function (options) {
    //step03-b 合并用户自定义属性,默认属性
    var options = $.extend(defaults, options);
    }
})(jQuery);

   

  

其中:var options = $.extend(defaults, options)的含义了。表示 options 去覆盖了defaults的值,并把值赋给了options。
在插件环境中,就表示用户设置的值,覆盖了插件的默认值;如果用户没有设置默认值的属性,还是保留插件的默认值。

4. 支持jquery选择器:

//step01 定义JQuery的作用域
(function ($) {
    //step03-a 插件的默认值属性
  var defaults = {
      prevId: 'prevBtn',
    prevText: 'Previous',
    nextId: 'nextBtn',
    nextText: 'Next'
    //……
  };

//step02 插件的扩展方法名称
$.fn.easySlider = function (options) {
    //step03-b 合并用户自定义属性,默认属性
  var options = $.extend(defaults, options);
    //step4 支持JQuery选择器
    this.each(function () {
  
    });
  }
})(jQuery);

  

5 .支持JQuery的链接调用:

为了能达到链接调用的效果必须要把循环的每个元素return

//step01 定义JQuery的作用域
(function ($) {
    //step03-a 插件的默认值属性
    var defaults = {
        prevId: 'prevBtn',
        prevText: 'Previous',
        nextId: 'nextBtn',
        nextText: 'Next'
        //……
    };
    //step02 插件的扩展方法名称
    $.fn.easySlider = function (options) {
        //step03-b 合并用户自定义属性,默认属性
        var options = $.extend(defaults, options);
        //step4 支持JQuery选择器
        //step5 支持链式调用
        return this.each(function () {
  
        });
    }
})(jQuery);

  

6. 插件里的方法:
在插件里定义的方法,外界不能直接调用,我在插件里定义的方法也没有污染外界环境。

//step01 定义JQuery的作用域
(function ($) {
    //step03-a 插件的默认值属性
    var defaults = {
        prevId: 'prevBtn',
        prevText: 'Previous',
        nextId: 'nextBtn',
        nextText: 'Next'
        //……
    };
    //step06-a 在插件里定义方法
    var showLink = function (obj) {
        $(obj).append(function () { return "(" + $(obj).attr("href") + ")" });
    }
 
    //step02 插件的扩展方法名称
    $.fn.easySlider = function (options) {
        //step03-b 合并用户自定义属性,默认属性
        var options = $.extend(defaults, options);
        //step4 支持JQuery选择器
        //step5 支持链式调用
        return this.each(function () {
            //step06-b 在插件里定义方法
            showLink(this);
        });
    }
})(jQuery);


推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式