豆瓣的jQuery使用技巧

Douban是2.0 社区里面比较成功的一个产品, 里面ajax技术也做得不错, 把它的源码拿来研究了一下, 它在页面上使用了jquery,  我比较喜欢它的一体式的事件处理机制,不用写很多的事件绑定代码,只需要通过一定的命名规则就可以自动给页面元素加上一些功能, 它上面几乎所有的功能都通过这个实现, 配合jquery强大的选择器,代码看起来比较简洁清晰.  下面我们就来看看它的一些核心部分. 我使用的是jquery 1.2.3,压缩之后29kb大小, 速度感觉上比以前有比较大的改善.废话不多说了,直接看看代码吧. 另外推荐一下blueprint 这个css框架,还挺好用的.

图片[1]-豆瓣的jQuery使用技巧-千百度社区
//
定义命名空间

图片[2]-豆瓣的jQuery使用技巧-千百度社区

var
 Bowtech
=
new
 Object();
图片[1]-豆瓣的jQuery使用技巧-千百度社区
图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
注册全局的事件监视器.

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

Bowtech.EventMonitor 
=
 
function
()
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[7]-豆瓣的jQuery使用技巧-千百度社区    
this.listeners = new Object();
图片[8]-豆瓣的jQuery使用技巧-千百度社区}


图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
广播事件

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

Bowtech.EventMonitor.prototype.broadcast
=
function
(widgetObj, msg, data)
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[12]-豆瓣的jQuery使用技巧-千百度社区    
var lst = this.listeners[msg];
图片[13]-豆瓣的jQuery使用技巧-千百度社区
图片[14]-豆瓣的jQuery使用技巧-千百度社区图片[14]-豆瓣的jQuery使用技巧-千百度社区    
if(lst != null)图片[14]-豆瓣的jQuery使用技巧-千百度社区{
图片[15]-豆瓣的jQuery使用技巧-千百度社区图片[15]-豆瓣的jQuery使用技巧-千百度社区        
for(var o in lst)图片[15]-豆瓣的jQuery使用技巧-千百度社区{
图片[16]-豆瓣的jQuery使用技巧-千百度社区            lst[o](widgetObj, data);
图片[17]-豆瓣的jQuery使用技巧-千百度社区        }

图片[18]-豆瓣的jQuery使用技巧-千百度社区    }

图片[8]-豆瓣的jQuery使用技巧-千百度社区}


图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
绑定所有的事件. 

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

Bowtech.EventMonitor.prototype.subscribe
=
function
(msg, callback)
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[12]-豆瓣的jQuery使用技巧-千百度社区    
var lst = this.listeners[msg];
图片[24]-豆瓣的jQuery使用技巧-千百度社区图片[24]-豆瓣的jQuery使用技巧-千百度社区    
if (lst) 图片[24]-豆瓣的jQuery使用技巧-千百度社区{
图片[25]-豆瓣的jQuery使用技巧-千百度社区        lst.push(callback);
图片[26]-豆瓣的jQuery使用技巧-千百度社区图片[26]-豆瓣的jQuery使用技巧-千百度社区    }
 else 图片[26]-豆瓣的jQuery使用技巧-千百度社区{
图片[27]-豆瓣的jQuery使用技巧-千百度社区        
this.listeners[msg] = [callback];
图片[18]-豆瓣的jQuery使用技巧-千百度社区    }

图片[8]-豆瓣的jQuery使用技巧-千百度社区}


图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
取消事件绑定.

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

Bowtech.EventMonitor.prototype.unsubscribe
=
function
(msg, callback)
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[33]-豆瓣的jQuery使用技巧-千百度社区    
var lst = this.listener[msg];
图片[34]-豆瓣的jQuery使用技巧-千百度社区图片[34]-豆瓣的jQuery使用技巧-千百度社区    
if (lst != null)图片[34]-豆瓣的jQuery使用技巧-千百度社区{
图片[35]-豆瓣的jQuery使用技巧-千百度社区图片[35]-豆瓣的jQuery使用技巧-千百度社区        lst 
= lst.filter(function(ele, index, arr)图片[35]-豆瓣的jQuery使用技巧-千百度社区{return ele!=callback;});
图片[18]-豆瓣的jQuery使用技巧-千百度社区    }

图片[8]-豆瓣的jQuery使用技巧-千百度社区}


图片[1]-豆瓣的jQuery使用技巧-千百度社区
图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
 Page scope event-monitor obj.

图片[2]-豆瓣的jQuery使用技巧-千百度社区

var
 event_monitor 
=
 
new
 Bowtech.EventMonitor();
图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
对于所有 class=”j a_xxx yyy” id=”xxx-123″的元素执行事件绑定, xxx-123部分用来获取元素的ID,比如一个帖子的ID,

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

 a_xxx  后面的部

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

分用来标识应用如 vote / review / blog 等.

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

绑定的事件就是 :  Bowtech.init_vote / Bowtech.init_blog 等.

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

function
 load_event_monitor(root) 
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[47]-豆瓣的jQuery使用技巧-千百度社区    
var re = /a_(\w+)///正则表达式获取ID.
图片[48]-豆瓣的jQuery使用技巧-千百度社区图片[48]-豆瓣的jQuery使用技巧-千百度社区
    var fns = 图片[48]-豆瓣的jQuery使用技巧-千百度社区{};
图片[49]-豆瓣的jQuery使用技巧-千百度社区图片[49]-豆瓣的jQuery使用技巧-千百度社区    $(
.j, root).each(function(i) 图片[49]-豆瓣的jQuery使用技巧-千百度社区{
图片[50]-豆瓣的jQuery使用技巧-千百度社区        
var m = re.exec(this.className);
图片[51]-豆瓣的jQuery使用技巧-千百度社区图片[51]-豆瓣的jQuery使用技巧-千百度社区        
if (m) 图片[51]-豆瓣的jQuery使用技巧-千百度社区{
图片[52]-豆瓣的jQuery使用技巧-千百度社区            
var f = fns[m[1]];
图片[53]-豆瓣的jQuery使用技巧-千百度社区图片[53]-豆瓣的jQuery使用技巧-千百度社区            
if (!f) 图片[53]-豆瓣的jQuery使用技巧-千百度社区//如果事件处理函数不存在则创建函数对象.
图片[54]-豆瓣的jQuery使用技巧-千百度社区
                f = eval(Bowtech.init_+m[1]); 
图片[55]-豆瓣的jQuery使用技巧-千百度社区                fns[m[
1]] = f;//调用绑定函数.
图片[56]-豆瓣的jQuery使用技巧-千百度社区
            }

图片[57]-豆瓣的jQuery使用技巧-千百度社区            f 
&& f(this);
图片[17]-豆瓣的jQuery使用技巧-千百度社区        }

图片[59]-豆瓣的jQuery使用技巧-千百度社区    }
);
图片[8]-豆瓣的jQuery使用技巧-千百度社区}


图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
在文档加载完毕后将执行的方法(参见jquery文档)

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

一般来说文档加载的时候应该绑定所有的事件, 但是有一种情况例外.

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

比如 通过Ajax方法取回来的内容里面还含有动作按钮的,这时需要针对这部分功能执行绑定.

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

需要手动调用 load_event_monitor(element);  方法.

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

$(
function
() 
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[67]-豆瓣的jQuery使用技巧-千百度社区    load_event_monitor(document);
图片[8]-豆瓣的jQuery使用技巧-千百度社区}

);
图片[2]-豆瓣的jQuery使用技巧-千百度社区

//
注意这里的o对象是一个html 元素而非是一个jquery对象,所以在调用它的方法时应该使用$(o)函数

图片[42]-豆瓣的jQuery使用技巧-千百度社区//

把它转化为jquery对象.

图片[5]-豆瓣的jQuery使用技巧-千百度社区图片[5]-豆瓣的jQuery使用技巧-千百度社区

Bowtech.init_forder 
=
 
function
(o) 
图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[73]-豆瓣的jQuery使用技巧-千百度社区    
var eid = $(o).attr(id).split()[1];
图片[74]-豆瓣的jQuery使用技巧-千百度社区    
var fo = $(#f-+eid);
图片[75]-豆瓣的jQuery使用技巧-千百度社区    
var unfo = $(#unf-+eid);
图片[76]-豆瓣的jQuery使用技巧-千百度社区    
图片[77]-豆瓣的jQuery使用技巧-千百度社区图片[77]-豆瓣的jQuery使用技巧-千百度社区    fo.click(
function() 图片[77]-豆瓣的jQuery使用技巧-千百度社区{
图片[78]-豆瓣的jQuery使用技巧-千百度社区       $(o).hide();
图片[79]-豆瓣的jQuery使用技巧-千百度社区       unfo.show();
图片[80]-豆瓣的jQuery使用技巧-千百度社区       fo.hide();
图片[59]-豆瓣的jQuery使用技巧-千百度社区    }
);
图片[82]-豆瓣的jQuery使用技巧-千百度社区图片[82]-豆瓣的jQuery使用技巧-千百度社区    unfo.click(
function() 图片[82]-豆瓣的jQuery使用技巧-千百度社区{
图片[83]-豆瓣的jQuery使用技巧-千百度社区        $(o).show();
图片[84]-豆瓣的jQuery使用技巧-千百度社区        fo.show();
图片[85]-豆瓣的jQuery使用技巧-千百度社区        unfo.hide();
图片[59]-豆瓣的jQuery使用技巧-千百度社区    }
);
图片[8]-豆瓣的jQuery使用技巧-千百度社区}


图片[1]-豆瓣的jQuery使用技巧-千百度社区
图片[1]-豆瓣的jQuery使用技巧-千百度社区
图片[90]-豆瓣的jQuery使用技巧-千百度社区图片[90]-豆瓣的jQuery使用技巧-千百度社区jQuery.fn.extend(

图片[6]-豆瓣的jQuery使用技巧-千百度社区
{
图片[92]-豆瓣的jQuery使用技巧-千百度社区图片[92]-豆瓣的jQuery使用技巧-千百度社区    set_caret: 
function()图片[92]-豆瓣的jQuery使用技巧-千百度社区{
图片[93]-豆瓣的jQuery使用技巧-千百度社区        
if(!$.browser.msie) return;
图片[94]-豆瓣的jQuery使用技巧-千百度社区图片[94]-豆瓣的jQuery使用技巧-千百度社区        
var initSetCaret = function()图片[94]-豆瓣的jQuery使用技巧-千百度社区{this.caretPos = document.selection.createRange().duplicate()};
图片[95]-豆瓣的jQuery使用技巧-千百度社区        
this.click(initSetCaret).select(initSetCaret).keyup(initSetCaret);
图片[96]-豆瓣的jQuery使用技巧-千百度社区    }

图片[97]-豆瓣的jQuery使用技巧-千百度社区图片[97]-豆瓣的jQuery使用技巧-千百度社区    insert_caret:
function(textFeildValue)图片[97]-豆瓣的jQuery使用技巧-千百度社区{
图片[98]-豆瓣的jQuery使用技巧-千百度社区        
var textObj = this[0];
图片[99]-豆瓣的jQuery使用技巧-千百度社区图片[99]-豆瓣的jQuery使用技巧-千百度社区        
if(document.all && textObj.createTextRange && textObj.caretPos)图片[99]-豆瓣的jQuery使用技巧-千百度社区{
图片[100]-豆瓣的jQuery使用技巧-千百度社区            
var caretPos=textObj.caretPos;
图片[101]-豆瓣的jQuery使用技巧-千百度社区            caretPos.text 
= caretPos.text.charAt(caretPos.text.length1==  ? textFeildValue+ : textFeildValue;
图片[102]-豆瓣的jQuery使用技巧-千百度社区图片[102]-豆瓣的jQuery使用技巧-千百度社区        }
 else if(textObj.setSelectionRange)图片[102]-豆瓣的jQuery使用技巧-千百度社区{
图片[103]-豆瓣的jQuery使用技巧-千百度社区            
var rangeStart=textObj.selectionStart;
图片[104]-豆瓣的jQuery使用技巧-千百度社区            
var rangeEnd=textObj.selectionEnd;
图片[105]-豆瓣的jQuery使用技巧-千百度社区            
var tempStr1=textObj.value.substring(0,rangeStart);
图片[106]-豆瓣的jQuery使用技巧-千百度社区            
var tempStr2=textObj.value.substring(rangeEnd);
图片[107]-豆瓣的jQuery使用技巧-千百度社区            textObj.value
=tempStr1+textFeildValue+tempStr2;
图片[108]-豆瓣的jQuery使用技巧-千百度社区            textObj.focus();
图片[109]-豆瓣的jQuery使用技巧-千百度社区            
var len=textFeildValue.length;
图片[110]-豆瓣的jQuery使用技巧-千百度社区            textObj.setSelectionRange(rangeStart
+len,rangeStart+len);
图片[111]-豆瓣的jQuery使用技巧-千百度社区            textObj.blur();
图片[112]-豆瓣的jQuery使用技巧-千百度社区图片[112]-豆瓣的jQuery使用技巧-千百度社区        }
 else 图片[112]-豆瓣的jQuery使用技巧-千百度社区{
图片[113]-豆瓣的jQuery使用技巧-千百度社区            textObj.value
+=textFeildValue;
图片[17]-豆瓣的jQuery使用技巧-千百度社区        }

图片[18]-豆瓣的jQuery使用技巧-千百度社区    }

图片[8]-豆瓣的jQuery使用技巧-千百度社区}

)

前台要用就比较简单了,  只需要这样写:

图片[1]-豆瓣的jQuery使用技巧-千百度社区
<
div 
id
=”test2″
 class
=”mod”
>

图片[118]-豆瓣的jQuery使用技巧-千百度社区                

<
h3
>

图片[119]-豆瓣的jQuery使用技巧-千百度社区                    这里可以放标题
图片[118]-豆瓣的jQuery使用技巧-千百度社区                

h3>
图片[121]-豆瓣的jQuery使用技巧-千百度社区                
<div class=”j modb a_forder” id=”modb-1002″>
图片[122]-豆瓣的jQuery使用技巧-千百度社区                    这里是一些主要的内容
图片[123]-豆瓣的jQuery使用技巧-千百度社区                    
<dl>
图片[124]-豆瓣的jQuery使用技巧-千百度社区                        
<dt>Hello world dt>
图片[125]-豆瓣的jQuery使用技巧-千百度社区                        
<dd>
图片[126]-豆瓣的jQuery使用技巧-千百度社区                            hahaha
dd>
图片[127]-豆瓣的jQuery使用技巧-千百度社区                    
dl>
图片[128]-豆瓣的jQuery使用技巧-千百度社区                    这个实验在沙加的神舟本上完成
图片[129]-豆瓣的jQuery使用技巧-千百度社区                
div>
图片[130]-豆瓣的jQuery使用技巧-千百度社区                
<div class=”edit”>
图片[131]-豆瓣的jQuery使用技巧-千百度社区                    
<id=”f-1002″ class=”forder” href=”javascript:void(0);”>[收起] a> <id=”unf-1002″
图片[132]-豆瓣的jQuery使用技巧-千百度社区                        class
=”unforder” href=”javascript:void(0);”>[展开] a>
图片[129]-豆瓣的jQuery使用技巧-千百度社区                
div>
            
div>

样式就省略了, 大家可以自己写, 最后发两个效果图:
图片[134]-豆瓣的jQuery使用技巧-千百度社区
收起时的样子

千百度
© 版权声明
THE END
喜欢就支持一下吧
点赞14 分享
评论 抢沙发
头像
欢迎您留下宝贵的见解!
提交
头像

昵称

取消
昵称表情代码图片

    暂无评论内容