window.$=window.jQuery=jQuery

我們的目的實現(xiàn)以下功能:

window.jQuery = ???
window.$ = jQuery

var $div = $(‘div’)
$div.addClass(‘red’) // 可將所有 div 的 class 添加一個 red
$div.setText(‘hi’) // 可將所有 div 的 textContent 變?yōu)?hi

首先镣典,想用$和jQuery,直接聲明成全局變量

window.jQuery = function() {}    
window.$ = jQuery

我們要把jQuery和$封裝成一個方法唾琼,可以選中dom元素兄春。

在調(diào)用這個方法時,這里我們可以給它傳一個dom元素锡溯,也可以傳一個選擇器(字符串)赶舆。
我們默認(rèn)傳遞的是一個dom元素,即 let nodes = { 0: nodeOrSelector, length: 1 }祭饭;
然后再對傳遞的參數(shù)類型用typeof進(jìn)行判斷芜茵,如果是'string'類型,那么我們把它作為一個選擇器甜癞,用querySelectorAll來選中dom元素夕晓。
然后,將nodes返回悠咱。這就實現(xiàn)了用$和jQuery來作為選擇器選中dom元素蒸辆。而且我們返回的是一個純凈的偽數(shù)組征炼,沒有原生dom的方法和屬性。

window.jQuery = function(nodeOrSelector) {
  let nodes = {}
  if (typeof nodeOrSelector === 'string') {
    let temp = document.querySelectorAll(nodeOrSelector)
    for (let i = 0; i < temp.length; i++) {
      nodes[i] = temp[i]
    }
    nodes.length = temp.length
  } else if (nodeOrSelector instanceof Node) {
    nodes = {
      0: nodeOrSelector,
      length: 1
    }
  }
    return node()
}

然后躬贡,我們來對這個函數(shù)添加兩個方法谆奥。

$div.addClass(‘red’) // 可將所有 div 的 class 添加一個 red:

nodes.addClass = function(classes) {
    classes.forEach((value) => {
      for (let i = 0; i < nodes.length; i++) {
        node[i].classList.add(value)
      }
    })
  }

$div.setText(‘hi’) // 可將所有 div 的 textContent 變?yōu)?hi:

nodes.text = function(text) {
    if (text === undefined) {
      var texts = []
      for (let i = 0; i < nodes.length; i++) {
        texts.push(nodes[i].textContent)
      }
      return texts
    } else {
      for (let i = 0; i < nodes.length; i++) {
        nodes[i].textContent = text
      }
    }
  }

最終代碼如下:

window.jQuery = function(nodeOrSelector) {
  let nodes = {}
  if (typeof nodeOrSelector === 'string') {
    let temp = document.querySelectorAll(nodeOrSelector)
    for (let i = 0; i < temp.length; i++) {
      nodes[i] = temp[i]
    }
    nodes.length = temp.length
  } else if (nodeOrSelector instanceof Node) {
    nodes = {
      0: nodeOrSelector,
      length: 1
    }
  }

  nodes.addClass = function(classes) {
    classes.forEach((value) => {
      for (let i = 0; i < nodes.length; i++) {
        node[i].classList.add(value)
      }
    })
  }

  nodes.text = function(text) {
    if (text === undefined) {
      var texts = []
      for (let i = 0; i < nodes.length; i++) {
        texts.push(nodes[i].textContent)
      }
      return texts
    } else {
      for (let i = 0; i < nodes.length; i++) {
        nodes[i].textContent = text
      }
    }
  }

  return nodes
}
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市拂玻,隨后出現(xiàn)的幾起案子酸些,更是在濱河造成了極大的恐慌,老刑警劉巖檐蚜,帶你破解...
    沈念sama閱讀 216,372評論 6 498
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件魄懂,死亡現(xiàn)場離奇詭異,居然都是意外死亡闯第,警方通過查閱死者的電腦和手機市栗,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,368評論 3 392
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來咳短,“玉大人填帽,你說我怎么就攤上這事×茫” “怎么了篡腌?”我有些...
    開封第一講書人閱讀 162,415評論 0 353
  • 文/不壞的土叔 我叫張陵,是天一觀的道長勾效。 經(jīng)常有香客問我嘹悼,道長,這世上最難降的妖魔是什么葵第? 我笑而不...
    開封第一講書人閱讀 58,157評論 1 292
  • 正文 為了忘掉前任绘迁,我火速辦了婚禮,結(jié)果婚禮上卒密,老公的妹妹穿的比我還像新娘缀台。我一直安慰自己,他們只是感情好哮奇,可當(dāng)我...
    茶點故事閱讀 67,171評論 6 388
  • 文/花漫 我一把揭開白布膛腐。 她就那樣靜靜地躺著,像睡著了一般鼎俘。 火紅的嫁衣襯著肌膚如雪哲身。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,125評論 1 297
  • 那天贸伐,我揣著相機與錄音勘天,去河邊找鬼。 笑死,一個胖子當(dāng)著我的面吹牛脯丝,可吹牛的內(nèi)容都是我干的商膊。 我是一名探鬼主播,決...
    沈念sama閱讀 40,028評論 3 417
  • 文/蒼蘭香墨 我猛地睜開眼宠进,長吁一口氣:“原來是場噩夢啊……” “哼晕拆!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起材蹬,我...
    開封第一講書人閱讀 38,887評論 0 274
  • 序言:老撾萬榮一對情侶失蹤实幕,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后堤器,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體昆庇,經(jīng)...
    沈念sama閱讀 45,310評論 1 310
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,533評論 2 332
  • 正文 我和宋清朗相戀三年吼旧,在試婚紗的時候發(fā)現(xiàn)自己被綠了凰锡。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,690評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡圈暗,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出裕膀,到底是詐尸還是另有隱情员串,我是刑警寧澤,帶...
    沈念sama閱讀 35,411評論 5 343
  • 正文 年R本政府宣布昼扛,位于F島的核電站寸齐,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏抄谐。R本人自食惡果不足惜渺鹦,卻給世界環(huán)境...
    茶點故事閱讀 41,004評論 3 325
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望蛹含。 院中可真熱鬧毅厚,春花似錦、人聲如沸浦箱。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,659評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽酷窥。三九已至咽安,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間蓬推,已是汗流浹背妆棒。 一陣腳步聲響...
    開封第一講書人閱讀 32,812評論 1 268
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人糕珊。 一個月前我還...
    沈念sama閱讀 47,693評論 2 368
  • 正文 我出身青樓动分,卻偏偏與公主長得像,于是被迫代替她去往敵國和親放接。 傳聞我的和親對象是個殘疾皇子刺啦,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,577評論 2 353

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

  • 一、樣式篇 第1章 初識jQuery (1)環(huán)境搭建 進(jìn)入官方網(wǎng)站獲取最新的版本 http://jquery.co...
    凜0_0閱讀 3,380評論 0 44
  • 第1章 簡介 第2章 DOM節(jié)點的創(chuàng)建 2-1 DOM創(chuàng)建節(jié)點及節(jié)點屬性 通過JavaScript可以很方便的獲...
    mo默22閱讀 810評論 0 8
  • (續(xù)jQuery基礎(chǔ)(1)) 第5章 DOM節(jié)點的復(fù)制與替換 (1)DOM拷貝clone() 克隆節(jié)點是DOM的常...
    凜0_0閱讀 1,336評論 0 8
  • DOM創(chuàng)建節(jié)點及節(jié)點屬性 通過JavaScript可以很方便的獲取DOM節(jié)點纠脾,從而進(jìn)行一系列的DOM操作玛瘸。但實際上...
    阿r阿r閱讀 1,013評論 0 9
  • 我們的目標(biāo),能夠?qū)崿F(xiàn)以下功能 window.jQuery = ??? window.$ = jQuery var ...
    longqinusi閱讀 242評論 0 0