深入理解JQuery原理

本文將手把手逐漸實現(xiàn)一個簡化版的 JQuery

先來自己動手簡化選擇器

base 是一個對象,擁有兩個方法,方法名為 $价淌、$$申眼,功能分別為通過 idclass 來獲取元素。

var base = {
    $:function(id){
        return document.getElementById(id);
    },
    $$:function(className){
        return document.getElementsByClassName(className);
    }
}

//使用
base.$("id");       //返回相應(yīng)的元素對象
base.$$("class");   //返回相應(yīng)的元素對象集合

進(jìn)階蝉衣,向JQuery靠攏

聲明一個全局方法 $括尸,用于返回一個 base 對象。

var $ = function(){
    return new Base();
}
function Base(){
    this.$ = function(id){
        return document.getElementById(id);
    };

    this.$$ = function(className){
        return document.getElementsByClassName(className);
    };
}

//使用
$().$("id");       //返回相應(yīng)的元素對象
$().$$("class");   //返回相應(yīng)的元素對象集合

加上css方法

增加 css 方法病毡,就可以通過 el.css().css() 鏈?zhǔn)秸{(diào)用的形式給元素增加樣式濒翻。

var $ = function(){
    return new Base();
}
function Base(){
    this.elements = []  //創(chuàng)建一個數(shù)組,來保存獲取的節(jié)點和節(jié)點數(shù)組

    this.$ = function(id){
        //因為每一次使用$都會新建對象啦膜,所以不需要清空有送,不會異常
        this.elements.push(document.getElementById(id));
        return this;  //一定要返回對象,不然無法進(jìn)行連綴
    };

    this.$$ = function(className){
        var clss = document.getElementsByClassName(className);
        for(var i = 0 ;i < clss.length; i++){
            this.elements.push(clss[i]);
        }
        return this;
    };

    this.css = function(attr,val){
        for(var i = 0;i < this.elements.length; i++){
            this.elements[i].style[attr] = val;
        }
        return this;
    }
}

//使用
$().$("id").css("color","white").css("background","black");       //返回相應(yīng)的元素對象
$().$$("class").css("color","red").css("border","1px dotted black");   //返回相應(yīng)的元素對象集合

加上eq方法

用于遍歷元素僧家,添加一個 current 變量即可

var $ = function(){
    return new Base();
}
function Base(){
    this.elements = [];  //創(chuàng)建一個數(shù)組雀摘,來保存獲取的節(jié)點和節(jié)點數(shù)組
    this.current = -1;   //用于遍歷

    this.$ = function(id){
        //因為每一次使用$都會新建對象,所以不需要清空八拱,不會異常
        this.elements.push(document.getElementById(id));
        return this;  //一定要返回對象阵赠,不然無法進(jìn)行連綴
    };

    this.$$ = function(className){
        var clss = document.getElementsByClassName(className);
        for(var i = 0 ;i < clss.length; i++){
            this.elements.push(clss[i]);
        }
        return this;
    };

    this.eq = function(index){
        this.current = index;
        return this;
    }

    this.css = function(attr,val){
        if(this.current != -1)this.elements[this.current].style[attr] = val;
        else{
            for(var i = 0;i < this.elements.length; i++){
              this.elements[i].style[attr] = val;
            }
        }
        return this;
    }
}

//使用
$().$("id").css("color","white").css("background","black");       //返回相應(yīng)的元素對象
$().$$("class").eq(1).css("color","red").css("border","1px dotted black");   //返回相應(yīng)的元素對象集合

通過$("str")來獲取元素

進(jìn)一步封裝 $ 函數(shù),從而使得調(diào)用方法對標(biāo) JQuery肌稻。

$('#id').css().css()

$('.class').eq(2).css().css()

var $ = function(str){
    var base = new Base();
    if(str[0] == "#"){
      base.$(str.substr(1,str.length - 1));
    }
    else if(str[0] == '.'){
      base.$$(str.substr(1,str.length - 1));
    }
    else{
      //TagName
    }
    return base;
}
function Base(){
    this.elements = [];  //創(chuàng)建一個數(shù)組清蚀,來保存獲取的節(jié)點和節(jié)點數(shù)組
    this.current = -1;   //用于遍歷

    this.$ = function(id){
        //因為每一次使用$都會新建對象,所以不需要清空爹谭,不會異常
        this.elements.push(document.getElementById(id));
        return this;  //一定要返回對象枷邪,不然無法進(jìn)行連綴
    };

    this.$$ = function(className){
        var clss = document.getElementsByClassName(className);
        for(var i = 0 ;i < clss.length; i++){
            this.elements.push(clss[i]);
        }
        return this;
    };

    this.eq = function(index){
        this.current = index;
        return this;
    }

    this.css = function(attr,val){
        if(this.current != -1)this.elements[this.current].style[attr] = val;
        else{
            for(var i = 0;i < this.elements.length; i++){
              this.elements[i].style[attr] = val;
            }
        }
        return this;
    }
}

//使用
$("#id").css("color","white").css("background","black");       //返回相應(yīng)的元素對象
$(".class").eq(1).css("color","red").css("border","1px dotted black");   //返回相應(yīng)的元素對象集合
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市诺凡,隨后出現(xiàn)的幾起案子齿风,更是在濱河造成了極大的恐慌,老刑警劉巖绑洛,帶你破解...
    沈念sama閱讀 222,729評論 6 517
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件救斑,死亡現(xiàn)場離奇詭異,居然都是意外死亡真屯,警方通過查閱死者的電腦和手機(jī)脸候,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 95,226評論 3 399
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人运沦,你說我怎么就攤上這事泵额。” “怎么了携添?”我有些...
    開封第一講書人閱讀 169,461評論 0 362
  • 文/不壞的土叔 我叫張陵嫁盲,是天一觀的道長。 經(jīng)常有香客問我烈掠,道長羞秤,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 60,135評論 1 300
  • 正文 為了忘掉前任左敌,我火速辦了婚禮瘾蛋,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘矫限。我一直安慰自己哺哼,他們只是感情好,可當(dāng)我...
    茶點故事閱讀 69,130評論 6 398
  • 文/花漫 我一把揭開白布叼风。 她就那樣靜靜地躺著取董,像睡著了一般。 火紅的嫁衣襯著肌膚如雪无宿。 梳的紋絲不亂的頭發(fā)上甲葬,一...
    開封第一講書人閱讀 52,736評論 1 312
  • 那天,我揣著相機(jī)與錄音懈贺,去河邊找鬼经窖。 笑死,一個胖子當(dāng)著我的面吹牛梭灿,可吹牛的內(nèi)容都是我干的画侣。 我是一名探鬼主播,決...
    沈念sama閱讀 41,179評論 3 422
  • 文/蒼蘭香墨 我猛地睜開眼堡妒,長吁一口氣:“原來是場噩夢啊……” “哼配乱!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起皮迟,我...
    開封第一講書人閱讀 40,124評論 0 277
  • 序言:老撾萬榮一對情侶失蹤搬泥,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后伏尼,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體忿檩,經(jīng)...
    沈念sama閱讀 46,657評論 1 320
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 38,723評論 3 342
  • 正文 我和宋清朗相戀三年爆阶,在試婚紗的時候發(fā)現(xiàn)自己被綠了燥透。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片沙咏。...
    茶點故事閱讀 40,872評論 1 353
  • 序言:一個原本活蹦亂跳的男人離奇死亡,死狀恐怖班套,靈堂內(nèi)的尸體忽然破棺而出肢藐,到底是詐尸還是另有隱情,我是刑警寧澤吱韭,帶...
    沈念sama閱讀 36,533評論 5 351
  • 正文 年R本政府宣布吆豹,位于F島的核電站,受9級特大地震影響理盆,放射性物質(zhì)發(fā)生泄漏痘煤。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點故事閱讀 42,213評論 3 336
  • 文/蒙蒙 一熏挎、第九天 我趴在偏房一處隱蔽的房頂上張望速勇。 院中可真熱鬧晌砾,春花似錦坎拐、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,700評論 0 25
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至呕乎,卻和暖如春积担,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背猬仁。 一陣腳步聲響...
    開封第一講書人閱讀 33,819評論 1 274
  • 我被黑心中介騙來泰國打工帝璧, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人湿刽。 一個月前我還...
    沈念sama閱讀 49,304評論 3 379
  • 正文 我出身青樓的烁,卻偏偏與公主長得像,于是被迫代替她去往敵國和親诈闺。 傳聞我的和親對象是個殘疾皇子渴庆,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 45,876評論 2 361

推薦閱讀更多精彩內(nèi)容