这篇文章主要介绍了jQuery.extend 与 jQuery.fn.extend的用法及区别,结合实例形式分析了jQuery.extend与jQuery.fn.extend的功能、使用方法及区别,需要的朋友可以参考下
本文实例讲述了jQuery.extend 与 jQuery.fn.extend的用法及区别。分享给大家供大家参考,具体如下:
jQuery是一个JavaScript类,如$("#input1")
生成一个 jQuery类的实例。
jQuery为开发插件提拱了两个方法:jQuery.fn.extend()
和jQuery.extend()
。
1、jQuery.extend()
(1)扩展 jQuery 类本身,为jQuery类添加类方法(静态方法)
1 2 3 4 |
|
(2)jQuery.extend(object, object1, [objectN])
用一个或多个其他对象来扩展一个对象,返回被扩展的对象
1 2 3 |
|
2、jQuery.fn.extend()
把对象挂载到 jQuery 的 prototype
属性,来扩展一个新的 jQuery 实例方法,也就是通过这个 extend
添加的新方法,实例化的 jQuery 对象都能使用,因为它是挂载在 jQuery.fn
上的方法。
查看jQuery源码可发现,jQuery.fn = jQuery.prototype
。jQuery.fn挂在原型上,由于对原型的修改会影响所有实例,因此fn上的方法会对每一个jQuery实例有效。
对jQuery.fn
的扩展,就是为jQuery类添加成员函数,jQuery类的实例可以使用这个成员函数。
1 2 3 4 5 6 7 8 |
|
3、jQuery.extend()
与 jQuery.fn.extend()
的区别
jQuery.extend()
是为jQuery类添加类方法(静态方法),需要通过jQuery类来调用(直接使用 $.xxx 调用);
jQuery.fn.extend()
是为jQuery类添加成员函数(实例方法),所有jQuery实例都可以直接调用(需要使用 $().xxx 调用)。