编写插件的目的是给已经有的一系列方法或函数做一个封装,以便在其他地方重复使用,方便后期维护和提高开发效率。
JQuery插件主要类型:
1.封装对象方法的插件 这种插件是将对象方法封装起来,用于对通过选择器获取jquery对象进行操作,是最常见的一种插件。
2.封装全局函数的插件 可以将独立的函数加到jquery命名空间下,例如jquery.AJAX()。
3.选择器插件 个别情况下会使用到选择器插件。
JQuery插件的特点:
1.命名推荐jquery.[插件名].js;
2.所有对象方法都应当附加到jquery.fn对象上,所有全局函数附加到jquery本身;
3.插件内部this指向通过选择器获取的jquery对象,而不是像一般方法那样click(),内部this指向的dom元素;
4.可以通过this.each()遍历所有元素;
5.插件以分号结尾,保障压缩的时候不会出现问题,稳妥期间可以在头部加一个分号;
6.插件应该返回一个jquery对象,以保障插件的可链式操作。除非插件需要返回的是一些需要获取的量,例如字符串或者数组等;
7.避免在插件内部使用$作为jquery的别名,使用完整的jquery来表示,可以利用闭包解决这种问题;
插件中的闭包:
;(function($){
/*这里放置代码*/
var foo;
var bar=function(){
};
/*下面语句让匿名函数内部的函数bar()逃逸到全局可访问的范围内
这样可以在匿名函数的外部通过调用jquery.BAR来访问内部的bar();
*/
$.BAR=bar;
})(jQuery)