jquery插件开发一般有两种方法:
1 通过$.extend()来扩展,写成jQuery.extend()也可以的
2 通过$.fn.extend()来进行扩展,也可以写成jQuery.fn.extend()
第一种方法,相当于在$身上添加了一个全局函数,如果和后台java、c#类比的话,就是相当于在
$或jQuey这个类上添加了一个静态的方法(函数)
那怎么写?
把通过第一种方法扩展的插件写在这个common.js文件里,然后在index.html页面去测试
代码:
非常简单的一行代码
然后看index.html页面调用
然后看控制台输出:
一切都是妥妥的,没毛病,而且其他页面如果引用了,都能使用这个方法。
但是如果需要定义多个全局的函数,通常我们用面向对象的思想来编写。
例如:
将所有的成员都挂在一个对象上,或者说是放在一个命令空间里。这样做的好处就是,不用定义太多的外部变量,避免引起冲突。
调用:
调用的话就是: $.对象名.成员。
结果:
当然我们也可以用jQuery提供给我们用于扩展用的行数extend()
例如:
调用:
结果:
前面的这些都属于第一种方法的范畴,本质就是在$上添加全局函数就可以了。
再看第二种方式$.fn.extend(),这种方式相当于给$的每一个实例对象添加方法(函数)
首先我们要知道fn是个什么鬼,查看jQuery源代码,会发现这样的一行代码:
说明我们就是在原型上去做的扩展。
例如:
注意:index是对应的索引,ele对应的是每一个dom元素对象
最后一样的return是用于支持链式调用的。
调用:
最后的效果:
如果要扩展多个方法,这个时候就需要这样写了
显然比较麻烦!
还是一样可以使用jQuery提供给我们的方法(函数)$.fn.extend()
如果要扩展多个就可以这样写了
调用:
能够链式操作。
效果如图所示:
总结:
jQuey插件编写的两种方式:
1 $.extend(); // 在全局上添加函数 相当于静态方法(类比C#)
2 $.fn.extend(); // 相当于给jquey对象添加 相当于实例方法(类比C#)
再补充一点:
这个外面的this和里面的这个this不是同一个对象
查看其结果:
注意里面的每一个this对象都是dom对象