如何开发一个JQuery插件?

AJAX, Web开发

JQuery有两种开发插件的方法:

jQuery.fn.extend(object);

jQuery.extend(object);

jQuery.extend(object);方法为扩展jQuery类本身.并为类添加新的方法。

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

jQuery.fn = jQuery.prototype.

虽然 javascript 没有明确的类的概念,但是用类来理解它,会更方便。

jQuery便是一个封装得非常好的类,比如我们用 语句 $(“#btn1″) 会生成一个 jQuery类的实例。

jQuery.extend(object); 为jQuery类添加添加类方法,可以理解为添加静态方法。如:

$.extend({

add:function(a,b){return a+b;}

});

便为 jQuery 添加一个为 add 的 “静态方法”,之后便可以在引入 jQuery 的地方,使用这个方法了,

$.add(3,4);  //return 7

jQuery.fn.extend(object); 对jQuery.prototype进得扩展,就是为jQuery类添加“成员函数”。jQuery类的实例可以使用这个“成员函数”。

比如我们要开发一个插件,做一个特殊的编辑框,当它被点击时,便alert 当前编辑框里的内容。可以这么做:
Java代码

1. $.fn.extend({
2.
3.    alertWhileClick:function(){
4.
5.        $(this).click(function(){
6.
7.             alert($(this).val());
8.         });
9.
10.     }
11.
12. });
13.
14. $(“#input1″).alertWhileClick(); //页面上为:<input id=”input1″ type=”text”/>

$.fn.extend({

alertWhileClick:function(){

$(this).click(function(){

alert($(this).val());
});

}

});

$(“#input1″).alertWhileClick(); //页面上为:<input id=”input1″ type=”text”/>

$(“#input1″) 为一个jQuery实例,当它调用成员方法 alertWhileClick后,便实现了扩展,每次被点击时它会先弹出目前编辑里的内容。

jQuery提拱了丰富的操作文档,事件,CSS ,Ajax、效果的方法,结合这些方法,便可以开发出更加 Niubility 的插件。

同类其他面试题 点击新一篇或旧一篇可浏览全部同类面试题

新一篇:
旧一篇:

你有答案? 你对以上面试题有意见? 你想发表你的见解? 写下来吧!你的分享将会让很多人受益!

相关面试题

·Ajax获取页面被缓存的解决方法?
·Ajax跨域问题解决方案?
·jQuery Ajax中文乱码问题?
·几种流行的AJAX框架jQuery,Mootools,Dojo,Ext JS的对比
·ExtJS的优缺点
·Web应用中如何防止用户多次登录?
·Javascript面试题
·cookie是什么意思
·请简单介绍一下使用js脚本的好处以及其本身的特点
·百度笔试交互设计面试题

版权声明:本站大部分内容为原创! 另有少部分内容整理于网络,如需转载本站内容或关切版权事宜请联系站长。未经允许,严禁复制转载本站内容,否则将追究法律责任。 本站欢迎与同类网站建立友情链接,请联系QQ:176687814