天天躁日日躁狠狠躁AV麻豆-天天躁人人躁人人躁狂躁-天天澡夜夜澡人人澡-天天影视香色欲综合网-国产成人女人在线视频观看-国产成人女人视频在线观看

豆瓣的jQuery使用技巧

Douban是2.0 社區(qū)里面比較成功的一個(gè)產(chǎn)品, 里面ajax技術(shù)也做得不錯(cuò), 把它的源碼拿來(lái)研究了一下, 它在頁(yè)面上使用了jquery,  我比較喜歡它的一體式的事件處理機(jī)制,不用寫很多的事件綁定代碼,只需要通過(guò)一定的命名規(guī)則就可以自動(dòng)給頁(yè)面元素加上一些功能, 它上面幾乎所有的功能都通過(guò)這個(gè)實(shí)現(xiàn), 配合jquery強(qiáng)大的選擇器,代碼看起來(lái)比較簡(jiǎn)潔清晰.  下面我們就來(lái)看看它的一些核心部分. 我使用的是jquery 1.2.3,壓縮之后29kb大小, 速度感覺(jué)上比以前有比較大的改善.廢話不多說(shuō)了,直接看看代碼吧. 另外推薦一下blueprint 這個(gè)css框架,還挺好用的.

//定義命名空間
var Bowtech=new Object();

//注冊(cè)全局的事件監(jiān)視器.
Bowtech.EventMonitor = function(){
    
this.listeners = new Object();
}

//廣播事件
Bowtech.EventMonitor.prototype.broadcast=function(widgetObj, msg, data){
    
var lst = this.listeners[msg];

    
if(lst != null){
        
for(var o in lst){
            lst[o](widgetObj, data);
        }

    }

}

//綁定所有的事件. 
Bowtech.EventMonitor.prototype.subscribe=function(msg, callback){
    
var lst = this.listeners[msg];
    
if (lst) {
        lst.push(callback);
    }
 else {
        
this.listeners[msg] = [callback];
    }

}

//取消事件綁定.
Bowtech.EventMonitor.prototype.unsubscribe=function(msg, callback){
    
var lst = this.listener[msg];
    
if (lst != null){
        lst 
= lst.filter(function(ele, index, arr){return ele!=callback;});
    }

}


// Page scope event-monitor obj.
var event_monitor = new Bowtech.EventMonitor();
//對(duì)于所有 class="j a_xxx yyy" id="xxx-123"的元素執(zhí)行事件綁定, xxx-123部分用來(lái)獲取元素的ID,比如一個(gè)帖子的ID,
//
 a_xxx  后面的部
//
分用來(lái)標(biāo)識(shí)應(yīng)用如 vote / review / blog 等.
//
綁定的事件就是 :  Bowtech.init_vote / Bowtech.init_blog 等.
function load_event_monitor(root) {
    
var re = /a_(/w+)///正則表達(dá)式獲取ID.
    var fns = {};
    $(
".j", root).each(function(i) {
        
var m = re.exec(this.className);
        
if (m) {
            
var f = fns[m[1]];
            
if (!f) //如果事件處理函數(shù)不存在則創(chuàng)建函數(shù)對(duì)象.
                f = eval("Bowtech.init_"+m[1]); 
                fns[m[
1]] = f;//調(diào)用綁定函數(shù).
            }

            f 
&& f(this);
        }

    }
);
}

//在文檔加載完畢后將執(zhí)行的方法(參見jquery文檔)
//
一般來(lái)說(shuō)文檔加載的時(shí)候應(yīng)該綁定所有的事件, 但是有一種情況例外.
//
比如 通過(guò)Ajax方法取回來(lái)的內(nèi)容里面還含有動(dòng)作按鈕的,這時(shí)需要針對(duì)這部分功能執(zhí)行綁定.
//
需要手動(dòng)調(diào)用 load_event_monitor(element);  方法.
$(function() {
    load_event_monitor(document);
}
);
//注意這里的o對(duì)象是一個(gè)html 元素而非是一個(gè)jquery對(duì)象,所以在調(diào)用它的方法時(shí)應(yīng)該使用$(o)函數(shù)
//
把它轉(zhuǎn)化為jquery對(duì)象.
Bowtech.init_forder = function(o) {
    
var eid = $(o).attr("id").split("-")[1];
    
var fo = $("#f-"+eid);
    
var unfo = $("#unf-"+eid);
    
    fo.click(
function() {
       $(o).hide();
       unfo.show();
       fo.hide();
    }
);
    unfo.click(
function() {
        $(o).show();
        fo.show();
        unfo.hide();
    }
);
}



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

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

    }

}
)

it知識(shí)庫(kù)豆瓣的jQuery使用技巧,轉(zhuǎn)載需保留來(lái)源!

鄭重聲明:本文版權(quán)歸原作者所有,轉(zhuǎn)載文章僅為傳播更多信息之目的,如作者信息標(biāo)記有誤,請(qǐng)第一時(shí)間聯(lián)系我們修改或刪除,多謝。

主站蜘蛛池模板: 国产亚洲精品精品国产亚洲综合 | 亚洲精品午夜久久久伊人 | 日本久久久WWW成人免费毛片丨 | 毛片基地看看成人免费 | 美女漏bb | 麻豆免费高清完整版 | 色琪琪久久热在线 | wankz tv videos国产 | 国产午夜三级一区二区三 | 丰满女友bd高清在线观看 | 国产精品久久久精品日日 | 欧美午夜免费观看福利片 | xxxx88| 国产区精品综合在线 | 秋霞电影在线观看午夜伦 | 一个人看的www视频动漫版 | 久久中文字幕乱码免费 | 色婷婷狠狠97成为人免费 | 99久久婷婷国产综合精品青草 | 红尘影院在线观看 | 2021乱码精品公司 | 用快播看av的网站 | 欧美xxxx性喷潮 | 国产热久久精 | 亚洲成年男人的天堂网 | 毛片内射久久久一区 | 超碰在线97久久视频观看 | 亚洲午夜AV久久久精品影院色戒 | WWW污污污抽搐喷潮COM | 男女后进式猛烈xx00动态图片 | 2021精品高清卡1卡2卡3麻豆 | 日本免费一区二区三区最新vr | 7723日本高清完整版在线观看 | 2020最新国产自产精品 | 桃色窝 | 中国国产不卡视频在线观看 | 动漫美女和男人下载 | 亚洲免费视频观看 | 久久免费精彩视频 | 二色AV天堂在线 | free俄罗斯性xxxxhd派对 |