您现在的位置:首页 >> 前端 >> 内容

豆瓣的jQuery使用技巧

时间:2018/7/10 14:03:56 点击:

  核心提示:Douban是2.0 社区里面比较成功的一个产品, 里面ajax技术也做得不错, 把它的源码拿来研究了一下, 它在页面上使用了jquery, 我比较喜欢它的一体式的事件处理机制,不用写很多的事件绑定代...

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

豆瓣的jQuery使用技巧//定义命名空间
豆瓣的jQuery使用技巧
var Bowtech=new Object();
豆瓣的jQuery使用技巧
豆瓣的jQuery使用技巧
//注册全局的事件监视器.
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
Bowtech.EventMonitor = function(){
豆瓣的jQuery使用技巧    
this.listeners = new Object();
豆瓣的jQuery使用技巧}

豆瓣的jQuery使用技巧
//广播事件
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
Bowtech.EventMonitor.prototype.broadcast=function(widgetObj, msg, data){
豆瓣的jQuery使用技巧    
var lst = this.listeners[msg];
豆瓣的jQuery使用技巧
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    
if(lst != null){
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        
for(var o in lst){
豆瓣的jQuery使用技巧            lst[o](widgetObj, data);
豆瓣的jQuery使用技巧        }

豆瓣的jQuery使用技巧    }

豆瓣的jQuery使用技巧}

豆瓣的jQuery使用技巧
//绑定所有的事件. 
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
Bowtech.EventMonitor.prototype.subscribe=function(msg, callback){
豆瓣的jQuery使用技巧    
var lst = this.listeners[msg];
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    
if (lst) {
豆瓣的jQuery使用技巧        lst.push(callback);
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    }
 else {
豆瓣的jQuery使用技巧        
this.listeners[msg] = [callback];
豆瓣的jQuery使用技巧    }

豆瓣的jQuery使用技巧}

豆瓣的jQuery使用技巧
//取消事件绑定.
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
Bowtech.EventMonitor.prototype.unsubscribe=function(msg, callback){
豆瓣的jQuery使用技巧    
var lst = this.listener[msg];
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    
if (lst != null){
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        lst 
= lst.filter(function(ele, index, arr){return ele!=callback;});
豆瓣的jQuery使用技巧    }

豆瓣的jQuery使用技巧}

豆瓣的jQuery使用技巧
豆瓣的jQuery使用技巧
// Page scope event-monitor obj.
豆瓣的jQuery使用技巧
var event_monitor = new Bowtech.EventMonitor();
豆瓣的jQuery使用技巧
//对于所有 class="j a_xxx yyy" id="xxx-123"的元素执行事件绑定, xxx-123部分用来获取元素的ID,比如一个帖子的ID,
豆瓣的jQuery使用技巧//
 a_xxx  后面的部
豆瓣的jQuery使用技巧//
分用来标识应用如 vote / review / blog 等.
豆瓣的jQuery使用技巧//
绑定的事件就是 :  Bowtech.init_vote / Bowtech.init_blog 等.
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
function load_event_monitor(root) {
豆瓣的jQuery使用技巧    
var re = /a_(\w+)///正则表达式获取ID.
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
    var fns = {};
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    $(
".j", root).each(function(i) {
豆瓣的jQuery使用技巧        
var m = re.exec(this.className);
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        
if (m) {
豆瓣的jQuery使用技巧            
var f = fns[m[1]];
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧            
if (!f) //如果事件处理函数不存在则创建函数对象.
豆瓣的jQuery使用技巧
                f = eval("Bowtech.init_"+m[1]); 
豆瓣的jQuery使用技巧                fns[m[
1]] = f;//调用绑定函数.
豆瓣的jQuery使用技巧
            }

豆瓣的jQuery使用技巧            f 
&& f(this);
豆瓣的jQuery使用技巧        }

豆瓣的jQuery使用技巧    }
);
豆瓣的jQuery使用技巧}

豆瓣的jQuery使用技巧
//在文档加载完毕后将执行的方法(参见jquery文档)
豆瓣的jQuery使用技巧//
一般来说文档加载的时候应该绑定所有的事件, 但是有一种情况例外.
豆瓣的jQuery使用技巧//
比如 通过Ajax方法取回来的内容里面还含有动作按钮的,这时需要针对这部分功能执行绑定.
豆瓣的jQuery使用技巧//
需要手动调用 load_event_monitor(element);  方法.
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
$(function() {
豆瓣的jQuery使用技巧    load_event_monitor(document);
豆瓣的jQuery使用技巧}
);
豆瓣的jQuery使用技巧
//注意这里的o对象是一个html 元素而非是一个jquery对象,所以在调用它的方法时应该使用$(o)函数
豆瓣的jQuery使用技巧//
把它转化为jquery对象.
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧
Bowtech.init_forder = function(o) {
豆瓣的jQuery使用技巧    
var eid = $(o).attr("id").split("-")[1];
豆瓣的jQuery使用技巧    
var fo = $("#f-"+eid);
豆瓣的jQuery使用技巧    
var unfo = $("#unf-"+eid);
豆瓣的jQuery使用技巧    
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    fo.click(
function() {
豆瓣的jQuery使用技巧       $(o).hide();
豆瓣的jQuery使用技巧       unfo.show();
豆瓣的jQuery使用技巧       fo.hide();
豆瓣的jQuery使用技巧    }
);
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    unfo.click(
function() {
豆瓣的jQuery使用技巧        $(o).show();
豆瓣的jQuery使用技巧        fo.show();
豆瓣的jQuery使用技巧        unfo.hide();
豆瓣的jQuery使用技巧    }
);
豆瓣的jQuery使用技巧}

豆瓣的jQuery使用技巧
豆瓣的jQuery使用技巧
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧jQuery.fn.extend(
{
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    set_caret: 
function(){
豆瓣的jQuery使用技巧        
if(!$.browser.msie) return;
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        
var initSetCaret = function(){this.caretPos = document.selection.createRange().duplicate()};
豆瓣的jQuery使用技巧        
this.click(initSetCaret).select(initSetCaret).keyup(initSetCaret);
豆瓣的jQuery使用技巧    }

豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧    insert_caret:
function(textFeildValue){
豆瓣的jQuery使用技巧        
var textObj = this[0];
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        
if(document.all && textObj.createTextRange && textObj.caretPos){
豆瓣的jQuery使用技巧            
var caretPos=textObj.caretPos;
豆瓣的jQuery使用技巧            caretPos.text 
= caretPos.text.charAt(caretPos.text.length-1== '' ? textFeildValue+'' : textFeildValue;
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        }
 else if(textObj.setSelectionRange){
豆瓣的jQuery使用技巧            
var rangeStart=textObj.selectionStart;
豆瓣的jQuery使用技巧            
var rangeEnd=textObj.selectionEnd;
豆瓣的jQuery使用技巧            
var tempStr1=textObj.value.substring(0,rangeStart);
豆瓣的jQuery使用技巧            
var tempStr2=textObj.value.substring(rangeEnd);
豆瓣的jQuery使用技巧            textObj.value
=tempStr1+textFeildValue+tempStr2;
豆瓣的jQuery使用技巧            textObj.focus();
豆瓣的jQuery使用技巧            
var len=textFeildValue.length;
豆瓣的jQuery使用技巧            textObj.setSelectionRange(rangeStart
+len,rangeStart+len);
豆瓣的jQuery使用技巧            textObj.blur();
豆瓣的jQuery使用技巧豆瓣的jQuery使用技巧        }
 else {
豆瓣的jQuery使用技巧            textObj.value
+=textFeildValue;
豆瓣的jQuery使用技巧        }

豆瓣的jQuery使用技巧    }

豆瓣的jQuery使用技巧}
)


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

豆瓣的jQuery使用技巧<div id="test2" class="mod">
豆瓣的jQuery使用技巧                
<h3>
豆瓣的jQuery使用技巧                    这里可以放标题
豆瓣的jQuery使用技巧                
h3>
豆瓣的jQuery使用技巧                
<div class="j modb a_forder" id="modb-1002">
豆瓣的jQuery使用技巧                    这里是一些主要的内容
豆瓣的jQuery使用技巧                    
<dl>
豆瓣的jQuery使用技巧                        
<dt>Hello worlddt>
豆瓣的jQuery使用技巧                        
<dd>
豆瓣的jQuery使用技巧                            hahaha
dd>
豆瓣的jQuery使用技巧                    
dl>
豆瓣的jQuery使用技巧                    这个实验在沙加的神舟本上完成
豆瓣的jQuery使用技巧                
div>
豆瓣的jQuery使用技巧                
<div class="edit">
豆瓣的jQuery使用技巧                    
<id="f-1002" class="forder" href="javascript:void(0);">[收起]a> <id="unf-1002"
豆瓣的jQuery使用技巧                        class
="unforder" href="javascript:void(0);">[展开]a>
豆瓣的jQuery使用技巧                
div>
豆瓣的jQuery使用技巧            
div>


样式就省略了, 大家可以自己写, 最后发两个效果图:
豆瓣的jQuery使用技巧
收起时的样子
豆瓣的jQuery使用技巧

Tags:豆瓣 瓣的 的J JQ 
作者:沙加 来源:博客园