JQuery添加扩展方法(理解$.extend(),与$.fn.extend()方法区别)

理解$.extend(),与$.fn.extend()方法区别

1.$.extend()方法

$.extend()方法在JQuery中有两个用法,第一次是扩展方法,

第二个方法是

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

返回值:Object

把2个对象合并得到新的target,deep是可选的(递归合并)

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

jQuery 代码:
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" }

描述:

合并 defaults 和 options, 不修改 defaults。

jQuery 代码:
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" }

2中扩展:

第一种,看代码

$(function(){

            jQuery.extend({

                modalshow: function (options) {

                    var defaults = {

                        triggerID: ‘LoginShow‘,

                        callback: function () { }

                    }<br>       //这里是$.extend的第二种用法<br>       var opts = $.extend({},defaults, options);

                    if ($("#" + opts.triggerID)[0] == null) {

                        var $triggerBTN = $(‘<input type="button" value="LoginShow" id=‘ + opts.triggerID + ‘/>‘);

                        $triggerBTN.bind("click", function () {

                            alert(opts.triggerID);

                        });

                        $("body").append($triggerBTN);

                    } else {

                        $("#" + opts.triggerID).bind("click", function () {

                            alert(opts.triggerID);

                        })

                    }

                }

            });

            $.modalshow();//这里是调用的地方,id为‘loginshow‘的button可以先不再HTML中添加可以自动生成

        })

第二种扩展

$(function(){

            jQuery.fn.extend({

                modalshow: function (options) {

                    var defaults = {

                        //这里的this是JQuery对象

                        triggerID: this.attr("id"),

                        callback: function () { }

                    }<br>         //这里是$.extend的第二种用法<br>         var opts = $.extend(defaults, options);

                    $("#" + opts.triggerID).bind("click", function () {

                          alert(opts.triggerID);

                    })

                }

            });

            $("#loginShow").modalshow();//这里是调用的地方,这里需要先在HTML中加入元素

        })

时间: 2024-12-26 19:03:39

JQuery添加扩展方法(理解$.extend(),与$.fn.extend()方法区别)的相关文章

利用jQuery对插件进行扩展时,方法$.extend()、$.fn.extend()区别与联系

  利用JQ开发插件的方法: 1.jQuery.extend(); 2.jQuery.fn.extend(); 3.通过$.widget()应用jQuery UI的部件工厂方式创建. 由于第三种方式通常用于开发比较高级的jQuery的部件,开发难度较大,所以第一种和第二种方式用的更为广泛,下面主要对前两种方式的区别和联系以及使用的方法做一些介绍. 简要的说明一下: jQuery是一个封装的非常好的类,$(“#btn”)就相当于创建了一个jQuery的实例. 1.方法jQuery.fn .exte

jQuery 的方法扩展,$.extend()、$.fn.extend()和$.fn区别

$.extend(object) 是在jQuery的 类 上扩展,如 $.ajax(): $.fn.extend(object) 是在jQuery的 实例 上扩展,也就是在 jQuery.prototype 上添加 成员函数, 如: $.prototype.method = function(){}; $.fn 和 $.fn.extend(object) 都是添加 成员函数,是写法不一样 代码: (function($){ var fun = function(){ return { aa: f

jQuery中 $.extend 和 $.fn.extend 解释

$.extend() (1)第一种:拓展jQuery的全局(静态)函数的 方式:--->一个参数 例如: $.extend({ add : function(){ alert("1"); }, miu : function(){ alert("2"); } }) //此方式在jQuery对象本身:可以通过 jQuery.add(), jQuery.miu() 直接调用: (2)第二种:对象合并,即可以实现某个函数的重载:--->多个参数 例如: var

$.extend(),与$.fn.extend() 讲解

$.extend(),与$.fn.extend() 讲解(一) (2013-07-11 10:24:31) 转载▼ 转自:http://blog.sina.com.cn/s/blog_a3bd3bd0010187y1.html     jQuery插件的开发包括两种: 一种是类级别的插件开发,即给jQuery添加新的全局函数,相当于给jQuery类本身添加方法.jQuery的全局函数就是属于jQuery命名空间的函数,另一种是对象级别的插件开发,即给jQuery对象添加方法.下面就两种函数的开发

$.extend()和$.fn.extend()区别

$.extend()和$.fn.extend()用法和区别: 在自己制作插件的时候会经常用到$.extend()和$.fn.extend()两个函数,无论从外观还是作用都非常的类似,但是实际上它们的区别是巨大的,下面就简单介绍一下它们的区别是什么. 在javascript中,没有尽管没有类这个概念,但是作为一门面向对象的语言,其实是有着类似于类的实际应用,那么从标准面向对象的概念来说,jQuery就是一个封装好了的jQuery类,那么通过选择器获得的就是jQuery对象实例. 一.$.exten

$.extend()和$.fn.extend()函数用法简单介绍

$.extend()和$.fn.extend()函数用法简单介绍:标题中的两个方法在jQuery插件开发中非常的重要,下面通过简单的代码实例介绍一下它们的用法.本章节不会介绍它的原理,而是只给出它们的作用是什么,能够做什么事情.jQuery.extend()可以为jQuery类添加新的方法,类似于c#或者java中的静态方法.jQuery.fn.extend()可以为jQuery的对象实例添加新的方法.代码实例: <!DOCTYPE html> <html> <head>

插件的理解$.extend()与$.fn.extend()

插件的理解.$.extend()与$.fn.extend()    插件开发包括两种:1.类级别的插件开发,即$.extend()扩展jquery对象本身:2.对象级别的插件开发,即$.fn.extend()扩展jquery元素集来提供新的方法.    1.类级别的插件开发        1.(function($){                $.extend({                    hello:function(){alert("hello world");}

js插件 $.extend()与$.fn.extend() 基础

插件的理解.$.extend()与$.fn.extend()    插件开发包括两种:1.类级别的插件开发,即$.extend()扩展jquery对象本身:2.对象级别的插件开发,即$.fn.extend()扩展jquery元素集来提供新的方法.    1.类级别的插件开发        1.(function($){                $.extend({                    hello:function(){alert("hello world");}

jquery的extend和fn.extend

jQuery为开发插件提拱了两个方法,分别是: jQuery.fn.extend(object); jQuery.extend(object); jQuery.extend(object); 为扩展jQuery类本身.为类添加新的方法. jQuery.fn.extend(object);给jQuery对象添加方法. fn 是什么东西呢.查看jQuery代码,就不难发现. jQuery.fn = jQuery.prototype = { init: function( selector, cont