首页  >  问答  >  正文

javascript - 如何理解jQuery里面的$.extend和$.fn.extend?

在$.fn.extend()里面添加的方法,可以在jquery实例里面直接使用,而在$.extend()里面添加的方法,要使用$调用。
网上都说:jQuery.extend(object); 为扩展jQuery类本身,为类添加新的方法。

jQuery.fn.extend(object);给jQuery对象添加方法。

那么这个该怎么理解?object究竟添加到了哪里?jQuery.fn.extend(object);是把方法添加到原型上了吗?jQuery.extend(object);又是把方法添加到了哪里?要是添加到类本身,实例应该也可以使用吧?但是测试的结果是不能使用,必须用$.object这种方式调用。

阿神阿神2772 天前706

全部回复(7)我来回复

  • ringa_lee

    ringa_lee2017-04-11 12:45:31

    我现在想明白了。
    楼上的说的都是对的,我当时问这个问题的时候也都知道,我只是不明白$.extend()定义的方法为什么不能在jQuery对象里面调用。
    我的理解是本来jQuery这个对象就是return new jQuery.prototype.init()这种形式,所以根本就不是new的一个jQuery,所以自然不能直接调用$.extend()定义的方法,谢谢大家回答。

    回复
    0
  • 高洛峰

    高洛峰2017-04-11 12:45:31

    简单的说,$.extend是为jQuery这个构造函数本身添加方法。而$.fn.extend则是为构造函数jQuery生成的对象添加方法。

    举个简单的例子

    function Animal(){}
    
    var cat = new Animal{} 

    $.extend相当于

    Animal.eat=function(){}
    
    Animal.eat()//调用

    而$.fn.extend相当于

    Animal.prototype.eat=function(){}
    
    cat.eat()//调用

    回复
    0
  • 黄舟

    黄舟2017-04-11 12:45:31

    $.fn.extend === $.extend
    //true

    回复
    0
  • 大家讲道理

    大家讲道理2017-04-11 12:45:31

    $ 是一个构造函数,$.fn 这个fn是它的原型链吧

    回复
    0
  • 伊谢尔伦

    伊谢尔伦2017-04-11 12:45:31

    $.extend
    这种方式是给jQuery自己扩展方法。
    比如以下代码

    $.customFunc()//customFunc是你通过$.customFunc定义的

    $.fn.extend
    这种方式是给jQuery对象扩展方法,一般写插件用的多
    比如以下代码

    $('.title').test();//test是你自己通过$.fn.test定义的

    回复
    0
  • PHP中文网

    PHP中文网2017-04-11 12:45:31

    这里的fn实际就是指prototype;你就这样理解 $.fn.extend(xx);就相当于某个对象的构造函数的原型添加,比如 function Arry(){};Arry.prototype.XX=function(){};这个时候所有的数组对象就都有这个方法了。另一个是给对象直接添加,而不是在他的构造函数的原型基础上。

    回复
    0
  • ringa_lee

    ringa_lee2017-04-11 12:45:31

    建议看http://blog.csdn.net/ul646691...

    回复
    0
  • 取消回复