jquery插件开发一般有两种方法:

1 通过$.extend()来扩展,写成jQuery.extend()也可以的

2 通过$.fn.extend()来进行扩展,也可以写成jQuery.fn.extend()

第一种方法,相当于在$身上添加了一个全局函数,如果和后台java、c#类比的话,就是相当于在

$或jQuey这个类上添加了一个静态的方法(函数)

那怎么写?

jquery插件编写简单总结_ 插件

把通过第一种方法扩展的插件写在这个common.js文件里,然后在index.html页面去测试

代码:

jquery插件编写简单总结_jquery_02

非常简单的一行代码

然后看index.html页面调用

jquery插件编写简单总结_jquery_03

然后看控制台输出:

jquery插件编写简单总结_jquery_04

一切都是妥妥的,没毛病,而且其他页面如果引用了,都能使用这个方法。

但是如果需要定义多个全局的函数,通常我们用面向对象的思想来编写。

例如:

jquery插件编写简单总结_ 插件_05

将所有的成员都挂在一个对象上,或者说是放在一个命令空间里。这样做的好处就是,不用定义太多的外部变量,避免引起冲突。

调用:

jquery插件编写简单总结_jquery_06

调用的话就是: $.对象名.成员。

结果:

jquery插件编写简单总结_jquery_07

当然我们也可以用jQuery提供给我们用于扩展用的行数extend()

例如:

jquery插件编写简单总结_jquery_08

调用:

jquery插件编写简单总结_jquery_09

结果:

jquery插件编写简单总结_jquery_10

前面的这些都属于第一种方法的范畴,本质就是在$上添加全局函数就可以了。

再看第二种方式$.fn.extend(),这种方式相当于给$的每一个实例对象添加方法(函数)

首先我们要知道fn是个什么鬼,查看jQuery源代码,会发现这样的一行代码:

jquery插件编写简单总结_ 插件_11

说明我们就是在原型上去做的扩展。

例如:

jquery插件编写简单总结_jquery_12

注意:index是对应的索引,ele对应的是每一个dom元素对象

最后一样的return是用于支持链式调用的。

调用:

jquery插件编写简单总结_jquery_13

最后的效果:

jquery插件编写简单总结_ 插件_14

如果要扩展多个方法,这个时候就需要这样写了

jquery插件编写简单总结_ 插件_15

显然比较麻烦!

还是一样可以使用jQuery提供给我们的方法(函数)$.fn.extend()

如果要扩展多个就可以这样写了

jquery插件编写简单总结_jquery_16

调用:

jquery插件编写简单总结_jquery_17

能够链式操作。

效果如图所示:

jquery插件编写简单总结_jquery_18

总结:

jQuey插件编写的两种方式:

1 $.extend();     // 在全局上添加函数 相当于静态方法(类比C#)

2 $.fn.extend();    // 相当于给jquey对象添加   相当于实例方法(类比C#)

再补充一点:

jquery插件编写简单总结_ 插件_19

这个外面的this和里面的这个this不是同一个对象

查看其结果:

jquery插件编写简单总结_jquery_20

注意里面的每一个this对象都是dom对象