跟我一起学写jQuery插件(附完整实例及下载)

1.一个通用的框架

在动手写自己的jQuery插件之前,自然是先研究一下别人写的插件了。其实写jQuery也基本有一个通用的框架。行,那咱也把这框架照搬过来吧

(function($){
$.fn.yourName
= function(options){
//各种属性、参数
}
var options = $.extend(defaults, options);
this.each(function(){
//插件实现代码
});
};
})(jQuery);

 

2.名号、参数和属性

好不容易开始闯荡江湖了,一定要有一个响亮的名号才行,这样走在江湖上,才能够屌,够威风。不信,你听听人家“中国牙防组”!所以,咱这里一定要起个响亮的名号,一定要简单、明了、够权威。所以,决定了,就叫做“tableUI”了!

参数和属性也很简单,无非就是三个class的名称。就叫做:evenRowClass、oddRowClass和activeRowClass吧。

所以,上面的框架,咱就把上半身给填上了。

(function($){
$.fn.tableUI
= function(options){
var defaults = {
evenRowClass:
"evenRow",
oddRowClass:
"oddRow",
activeRowClass:
"activeRow"
}
var options = $.extend(defaults, options);
this.each(function(){
//实现代码
});
};
})(jQuery);

这里重点说一下这一句:

var options = $.extend(defaults, options);

 

看上去很屌的一句,其实就是合并多个对象为一个。这里就是,如果你在调用的时候写了新的参数,就用你新的参数,如果没有写,就用默认的参数。想进一步了解的朋友,可以参考jquery的官方文档:请猛点击这里 

ps:这是作者的源代码,但是更好的方式应该是这样

var options=$.extend({},defaults, options);


3.开始下半身吧

ok,上半身填补完了,咱就可以填补下半身吧。无非就是找到基数行和偶数行(感谢jQuery提供了类似tr:even这种写法,使其及其简单),然后添加上相应的class。然后再给所有的tr,绑定mouseover和mouseout事件即可。下半身代码如下

(function($){
$.fn.tableUI
= function(options){
var defaults = {
evenRowClass:
"evenRow",
oddRowClass:
"oddRow",
activeRowClass:
"activeRow"
}
var options = $.extend(defaults, options);
this.each(function(){
var thisTable=$(this);
//添加奇偶行颜色
$(thisTable).find("tr:even").addClass(options.evenRowClass);
$(thisTable).find(
"tr:odd").addClass(options.oddRowClass);
//添加活动行颜色
$(thisTable).find("tr").bind("mouseover",function(){
$(
this).addClass(options.activeRowClass);
});
$(thisTable).find(
"tr").bind("mouseout",function(){
$(
this).removeClass(options.activeRowClass);
});
});
};
})(jQuery);

 

4.最重要的一步!

许有些朋友觉得这样就算是完成了。但是切切相反,我们还有最重要的一步没有完成,那就是一定要在插件上方,写上插件的名称、版本号、完成日期、作者,作者的联系方式、出生日期、三围……等等。因为只有这样才能显的这个插件够专业
/*
* tableUI 0.1
* Copyright (c) 2009 JustinYoung http://justinyoung.cnblogs.com/
* Date: 2010-03-30
* 使用tableUI可以方便地将表格提示使用体验。先提供的功能有奇偶行颜色交替,鼠标移上高亮显示
*/
(
function($){
$.fn.tableUI
= function(options){
var defaults = {
evenRowClass:
"evenRow",
oddRowClass:
"oddRow",
activeRowClass:
"activeRow"
}
var options = $.extend(defaults, options);
this.each(function(){
var thisTable=$(this);
//添加奇偶行颜色
$(thisTable).find("tr:even").addClass(options.evenRowClass);
$(thisTable).find(
"tr:odd").addClass(options.oddRowClass);
//添加活动行颜色
$(thisTable).find("tr").bind("mouseover",function(){
$(
this).addClass(options.activeRowClass);
});
$(thisTable).find(
"tr").bind("mouseout",function(){
$(
this).removeClass(options.activeRowClass);
});
});
};
})(jQuery);

 

ps:上面是原作者的代码,但是在绑定的时候我推荐如下方式来实现
$(thisTable).find("tr").bind({
mouseover:
function()
{
$(
this).addClass(options.activeRowClass);
},
mouseout:
function(){
$(
this).removeClass(options.activeRowClass);
}
})

 

ok!来看看一个完整的实例吧!

没图没真相,没代码没真相。所以贴图和完整实例是必须的。

实例下载地址:猛点击这里


申明:本文系转载,ps内容为自己言论,原文地址:http://www.cnblogs.com/JustinYoung/.

    

posted on 2010-12-14 14:22  justcoder  阅读(401)  评论(0编辑  收藏  举报

导航