Douban的jquery使用技巧

Douban的jquery使用技巧

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

Douban的jquery使用技巧
//
定义命名空间

Douban的jquery使用技巧

var
 Bowtech
=
new
 Object();
Douban的jquery使用技巧
Douban的jquery使用技巧

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

Douban的jquery使用技巧Douban的jquery使用技巧

Bowtech.EventMonitor 
=
 
function
()
Douban的jquery使用技巧
{

Douban的jquery使用技巧    
this.listeners = new Object();
Douban的jquery使用技巧}


Douban的jquery使用技巧

//
广播事件

Douban的jquery使用技巧Douban的jquery使用技巧

Bowtech.EventMonitor.prototype.broadcast
=
function
(widgetObj, msg, data)
Douban的jquery使用技巧
{

Douban的jquery使用技巧    
var lst = this.listeners[msg];
Douban的jquery使用技巧
Douban的jquery使用技巧Douban的jquery使用技巧    
if(lst != null)Douban的jquery使用技巧{

Douban的jquery使用技巧Douban的jquery使用技巧        
for(var o in lst)Douban的jquery使用技巧{

Douban的jquery使用技巧            lst[o](widgetObj, data);
Douban的jquery使用技巧        }

Douban的jquery使用技巧    }

Douban的jquery使用技巧}


Douban的jquery使用技巧

//
绑定所有的事件. 

Douban的jquery使用技巧Douban的jquery使用技巧

Bowtech.EventMonitor.prototype.subscribe
=
function
(msg, callback)
Douban的jquery使用技巧
{

Douban的jquery使用技巧    
var lst = this.listeners[msg];
Douban的jquery使用技巧Douban的jquery使用技巧    
if (lst) Douban的jquery使用技巧{

Douban的jquery使用技巧        lst.push(callback);
Douban的jquery使用技巧Douban的jquery使用技巧    }
 else Douban的jquery使用技巧{

Douban的jquery使用技巧        
this.listeners[msg] = [callback];
Douban的jquery使用技巧    }

Douban的jquery使用技巧}


Douban的jquery使用技巧

//
取消事件绑定.

Douban的jquery使用技巧Douban的jquery使用技巧

Bowtech.EventMonitor.prototype.unsubscribe
=
function
(msg, callback)
Douban的jquery使用技巧
{

Douban的jquery使用技巧    
var lst = this.listener[msg];
Douban的jquery使用技巧Douban的jquery使用技巧    
if (lst != null)Douban的jquery使用技巧{

Douban的jquery使用技巧Douban的jquery使用技巧        lst 
= lst.filter(function(ele, index, arr)Douban的jquery使用技巧{
return ele!=callback;}
);
Douban的jquery使用技巧    }

Douban的jquery使用技巧}


Douban的jquery使用技巧
Douban的jquery使用技巧

//
 Page scope event-monitor obj.

Douban的jquery使用技巧

var
 event_monitor 
=
 
new
 Bowtech.EventMonitor();
Douban的jquery使用技巧

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

Douban的jquery使用技巧//

 a_xxx  后面的部

Douban的jquery使用技巧//

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

Douban的jquery使用技巧//

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

Douban的jquery使用技巧Douban的jquery使用技巧

function
 load_event_monitor(root) 
Douban的jquery使用技巧
{

Douban的jquery使用技巧    
var re = /a_(\w+)///正则表达式获取ID.
Douban的jquery使用技巧Douban的jquery使用技巧
    var fns = Douban的jquery使用技巧{};
Douban的jquery使用技巧Douban的jquery使用技巧    $(
.j, root).each(function(i) Douban的jquery使用技巧{

Douban的jquery使用技巧        
var m = re.exec(this.className);
Douban的jquery使用技巧Douban的jquery使用技巧        
if (m) Douban的jquery使用技巧{

Douban的jquery使用技巧            
var f = fns[m[1]];
Douban的jquery使用技巧Douban的jquery使用技巧            
if (!f) Douban的jquery使用技巧//如果事件处理函数不存在则创建函数对象.
Douban的jquery使用技巧
                f = eval(Bowtech.init_+m[1]); 
Douban的jquery使用技巧                fns[m[
1]] = f;//调用绑定函数.
Douban的jquery使用技巧
            }

Douban的jquery使用技巧            f 
&& f(this);
Douban的jquery使用技巧        }

Douban的jquery使用技巧    }
);
Douban的jquery使用技巧}


Douban的jquery使用技巧

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

Douban的jquery使用技巧//

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

Douban的jquery使用技巧//

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

Douban的jquery使用技巧//

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

Douban的jquery使用技巧Douban的jquery使用技巧

$(
function
() 
Douban的jquery使用技巧
{

Douban的jquery使用技巧    load_event_monitor(document);
Douban的jquery使用技巧}

);
Douban的jquery使用技巧

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

Douban的jquery使用技巧//

把它转化为jquery对象.

Douban的jquery使用技巧Douban的jquery使用技巧

Bowtech.init_forder 
=
 
function
(o) 
Douban的jquery使用技巧
{

Douban的jquery使用技巧    
var eid = $(o).attr(id).split()[1];
Douban的jquery使用技巧    
var fo = $(#f-+eid);
Douban的jquery使用技巧    
var unfo = $(#unf-+eid);
Douban的jquery使用技巧    
Douban的jquery使用技巧Douban的jquery使用技巧    fo.click(
function() Douban的jquery使用技巧{

Douban的jquery使用技巧       $(o).hide();
Douban的jquery使用技巧       unfo.show();
Douban的jquery使用技巧       fo.hide();
Douban的jquery使用技巧    }
);
Douban的jquery使用技巧Douban的jquery使用技巧    unfo.click(
function() Douban的jquery使用技巧{

Douban的jquery使用技巧        $(o).show();
Douban的jquery使用技巧        fo.show();
Douban的jquery使用技巧        unfo.hide();
Douban的jquery使用技巧    }
);
Douban的jquery使用技巧}


Douban的jquery使用技巧
Douban的jquery使用技巧
Douban的jquery使用技巧Douban的jquery使用技巧jQuery.fn.extend(

Douban的jquery使用技巧
{

Douban的jquery使用技巧Douban的jquery使用技巧    set_caret: 
function()Douban的jquery使用技巧{

Douban的jquery使用技巧        
if(!$.browser.msie) return;
Douban的jquery使用技巧Douban的jquery使用技巧        
var initSetCaret = function()Douban的jquery使用技巧{
this.caretPos = document.selection.createRange().duplicate()}
;
Douban的jquery使用技巧        
this.click(initSetCaret).select(initSetCaret).keyup(initSetCaret);
Douban的jquery使用技巧    }

Douban的jquery使用技巧Douban的jquery使用技巧    insert_caret:
function(textFeildValue)Douban的jquery使用技巧{

Douban的jquery使用技巧        
var textObj = this[0];
Douban的jquery使用技巧Douban的jquery使用技巧        
if(document.all && textObj.createTextRange && textObj.caretPos)Douban的jquery使用技巧{

Douban的jquery使用技巧            
var caretPos=textObj.caretPos;
Douban的jquery使用技巧            caretPos.text 
= caretPos.text.charAt(caretPos.text.length1==  ? textFeildValue+ : textFeildValue;
Douban的jquery使用技巧Douban的jquery使用技巧        }
 else if(textObj.setSelectionRange)Douban的jquery使用技巧{

Douban的jquery使用技巧            
var rangeStart=textObj.selectionStart;
Douban的jquery使用技巧            
var rangeEnd=textObj.selectionEnd;
Douban的jquery使用技巧            
var tempStr1=textObj.value.substring(0,rangeStart);
Douban的jquery使用技巧            
var tempStr2=textObj.value.substring(rangeEnd);
Douban的jquery使用技巧            textObj.value
=tempStr1+textFeildValue+tempStr2;
Douban的jquery使用技巧            textObj.focus();
Douban的jquery使用技巧            
var len=textFeildValue.length;
Douban的jquery使用技巧            textObj.setSelectionRange(rangeStart
+len,rangeStart+len);
Douban的jquery使用技巧            textObj.blur();
Douban的jquery使用技巧Douban的jquery使用技巧        }
 else Douban的jquery使用技巧{

Douban的jquery使用技巧            textObj.value
+=textFeildValue;
Douban的jquery使用技巧        }

Douban的jquery使用技巧    }

Douban的jquery使用技巧}

)

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

Douban的jquery使用技巧
<
div 
id
=”test2″
 class
=”mod”
>

Douban的jquery使用技巧                

<
h3
>

Douban的jquery使用技巧                    这里可以放标题
Douban的jquery使用技巧                

</
h3
>

Douban的jquery使用技巧                

<
div 
class
=”j modb a_forder”
 id
=”modb-1002″
>

Douban的jquery使用技巧                    这里是一些主要的内容
Douban的jquery使用技巧                    

<
dl
>

Douban的jquery使用技巧                        

<
dt
>
Hello world
</
dt
>

Douban的jquery使用技巧                        

<
dd
>

Douban的jquery使用技巧                            hahaha

</
dd
>

Douban的jquery使用技巧                    

</
dl
>

Douban的jquery使用技巧                    这个实验在沙加的神舟本上完成
Douban的jquery使用技巧                

</
div
>

Douban的jquery使用技巧                

<
div 
class
=”edit”
>

Douban的jquery使用技巧                    

<

id
=”f-1002″
 class
=”forder”
 href
=”javascript:void(0);”
>
[收起]
</
a
>
 
<

id
=”unf-1002″

Douban的jquery使用技巧                        class

=”unforder”
 href
=”javascript:void(0);”
>
[展开]
</
a
>

Douban的jquery使用技巧                

</
div
>

Douban的jquery使用技巧            

</
div
>

样式就省略了, 大家可以自己写, 最后发两个效果图:


Douban的jquery使用技巧

收起时的样子


Douban的jquery使用技巧

开发环境:  沙加的神舟本, VS2008, Framework 2.0

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/111035.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • jrebel 无效无法更换lisence

    jrebel 无效无法更换lisence

    2020年11月19日
    250
  • 大数据处理的基本流程是什么?[通俗易懂]

    写在前面本文隶属于专栏《100个问题搞定大数据理论体系》,该专栏为笔者原创,引用请注明来源,不足和错误之处请在评论区帮忙指出,谢谢!本专栏目录结构和文献引用请见100个问题搞定大数据理论体系解答大数据处理流程主要分为3步:1.数据抽取和集成2.数据分析3.数据解释补充1.数据抽取与集成由于大数据处理的数据来源类型丰富,利用多个数据库来接收来自客户端的数据,包括企业内部数据库、互联网数据和物联网数据,所以需要从数据中提取关系和实体,经过关联和聚合等操作,按照统一定义的格式对数据

    2022年4月9日
    78
  • 常用Python库_编程代码大全

    常用Python库_编程代码大全环境管理管理Python版本和环境的工具p–非常简单的交互式python版本管理工具。pyenv–简单的Python版本管理工具。Vex–可以在虚拟环境中执行命令。virtualenv–创建独立Python环境的工具。virtualenvwrapper-virtualenv的一组扩展。包管理管理包和依赖的工具。pip–Python包和依赖关系管理工具。pi…

    2022年8月27日
    7
  • html5是什么意思,HTML5是什么 HTML5是什么意思?

    html5是什么意思,HTML5是什么 HTML5是什么意思?随着Windows8正式版发布的脚步近在咫尺,近来关于Win8、IE10、HTML5的新闻逐渐增多,很多朋友对于Win8系统以及IE10浏览器都比较了解,但对于HTML5是什么还真有不少朋友不清楚,很多媒体网站在报道IE10浏览器支持最新html5的时候,不少朋友还是一头雾水,以下电脑百事网小编为大家简单介绍下HTML5是什么。HTML5是什么HTML5是什么意思专业的说,HTML5是用于取代1…

    2025年7月11日
    3
  • 什么是车载以太网_车载以太网结构

    什么是车载以太网_车载以太网结构SOME/IP(ScalableService-OrientedMiddlewarEoverIP):是一种用于传输服务(Service)信息的基于IP的可伸缩中间件,能够适应基于不同操作系统的不同大小的设备,小到摄像头,大到车机或自动驾驶模块;相比于传统的CAN总线的面向信号的通信方式,SOME/IP是一种面向服务的通信方式。 DoIP:基于以太网的诊断传输协…

    2025年8月21日
    3
  • 40个容易上瘾的HTML5网页游戏,总有一款适合你[通俗易懂]

    40个容易上瘾的HTML5网页游戏,总有一款适合你[通俗易懂]我记得姐姐家的孩子在刚刚才学会走路,说话还不能完整的时候就已经能自己用小手点出小游戏的网站来一个人自娱自乐。我一直在想这一代跟着计算机一起茁壮成长的孩子会不会也和美国那一代人一样,出现9岁的黑客和计算机天才。但是并不是信息的成长就能让教育同步。很多时候我们会发现教育在发展的大环境中并没有什么创新的思考。不管怎么说,我们还是需要小盆友们能有足够的想象力。不要被束缚!今天分享的是40个HTML5的网页

    2022年5月24日
    31

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号