DOM和BOM一些基礎(chǔ)用法

DOM

DOM常用節(jié)點(diǎn)類型

元素節(jié)點(diǎn) - 1;屬性節(jié)點(diǎn) - 2;文本節(jié)點(diǎn) - 3;注釋節(jié)點(diǎn) - 8;文檔節(jié)點(diǎn) - 9

查看節(jié)點(diǎn)

  • 查看元素下的子節(jié)點(diǎn)

    • el.children 子元素(不是標(biāo)準(zhǔn)中的操作)

      ? lastElementChild 最后一個(gè)子元素

    • el.childNodes 子節(jié)點(diǎn)(包括空白內(nèi)容和轉(zhuǎn)行內(nèi)容)

  • 查看元素的父元素(父節(jié)點(diǎn))

    • el.parentNode
  • 下一個(gè)兄弟元素

    • nextElementSibling 下一個(gè)兄弟元素(nextSibling 下一個(gè)兄弟節(jié)點(diǎn),包括文本節(jié)點(diǎn))
  • 上一個(gè)兄弟元素

    • previousElementSibling 上一個(gè)兄弟元素 (previousSibling 上一個(gè)兄弟節(jié)點(diǎn),包括文本節(jié)點(diǎn))

創(chuàng)建一個(gè)元素

object element createElement("tagName");

元素創(chuàng)建完,不添加到頁面中的話,看不到它

  • parent.appendChild(el);

    在parent中追加一個(gè)子元素el,(把el添加到parent的最末尾),如果操作的是一個(gè)已經(jīng)存在頁面中的元素,會把元素從原來的父級下,直接剪切過來

  • parentNode.insertBefore(childNode1,childNode2)

    往一個(gè)節(jié)點(diǎn)的指定子節(jié)點(diǎn)前邊插入一個(gè)節(jié)點(diǎn),如上:childNode1插入到childNode2前邊

刪除一個(gè)節(jié)點(diǎn)

  • parentNode.removeChild(childNodes)

    從一個(gè)節(jié)點(diǎn)中刪除指定的子節(jié)點(diǎn)。返回值: 被刪除的這個(gè)節(jié)點(diǎn)

    ?

定位父級

el.offsetParent

查找到el根據(jù)定位的父級元素,都沒有就查找到body

ofset

  • offsetWidth/offsetHeight 可視寬/高
  • offsetTop/offsetLeft 和定位父級之間的偏移

getBoundingClientRect()

  • 獲取元素的盒模型信息

    返回值對象 {

    ? left 元素左側(cè)相對于可視區(qū)左側(cè)的距離

    ? top 元素頂部相對于可視區(qū)頂部的距離

    ? right 元素右側(cè)相對于可視區(qū)左側(cè)的距離

    ? bottom 元素底部相對于可視區(qū)頂部的距離

    ? width 可視寬度

    ? height 可視高度

  • 獲取可視區(qū)寬高

    • document.documentElement.clientWidth;//可視區(qū)寬度
    • document.documentElement.clientHeight//可視區(qū)高度
  • client和offset的區(qū)別

    • offsetWidth/offsetHeight //width + padding + border

    • clientWidth/clientHeight //width + padding

      ?

    • offsetLeft/offsetTop //和定位父級之間的距離

    • clientLeft/clientTop //元素的邊框

屬性操作的第三種方法

注意: 盡量不要使用或者減少使用dom的操作,性能不太好

  • node.getAttribute(attr) 獲取元素指定屬性名的屬性值
  • node.setAttribute(attr,value) 設(shè)置元素指定屬性名的屬性值
  • node.removeAttribute(attr) 刪除元素的指定屬性

特點(diǎn):可以操作行間自定義的屬性;可以獲取src,href等的相對地址

節(jié)點(diǎn)操作

  • parentNode.replaceChild(node,childNode)
    • node用來替換的節(jié)點(diǎn),childNodes被替換的子節(jié)點(diǎn)
  • node.cloneNode(boolean) 克隆一個(gè)節(jié)點(diǎn)
    • true:克隆元素和元素包含的子孫節(jié)點(diǎn)
    • flase:克隆元素到但不包含元素的子孫節(jié)點(diǎn)

表格操作

  • table.tHead 獲取thead
  • table.tFoot 獲取tfoot
  • table.tBodies[i] 獲取tbody 注意table可以擁有多個(gè)tbody,所以獲取到的是一組
  • table.tHead.rows/table.rows 獲取tr 注意獲取到的是一組
  • table.rows[i].cells 獲取單元格 th,td 注意獲取到的是一組,單元格要在row里邊獲取

表單操作

  • input

    • text / radio / checkbox
  • select

  • textarea

    統(tǒng)一使用node.value獲取值

獲取 radio / checkbox 是否選中用node.checkbox

表單事件
  • onchange 主要用在 select / radio / checkbox / range 中 選中的狀態(tài)發(fā)生改變
  • oninput 輸入類型表單控件value發(fā)生變化
  • onfocus 當(dāng)元素獲得焦點(diǎn)時(shí)候
    • node.focus() 使元素得到焦點(diǎn)
  • onblur 當(dāng)元素失去焦點(diǎn)的時(shí)候
    • node.blur() 使元素失去焦點(diǎn)
  • onsubmit 當(dāng)表單提交的時(shí)候
    • node.submit 提交這個(gè)表單
  • onreset 當(dāng)表單重置的時(shí)候
    • node.reset() 重置這個(gè)表單

BOM

dom屬于bom(bom包含dom)

bom事件

  • window.open(url,打開方式,窗口特征)

    • 返回值:打開的新窗口的頁面屬性

    winow.open在高版本下的限制

    1. 只能在事件中操作,否則可能會被阻止掉
    2. 一個(gè)事件只能打開一個(gè),第二個(gè)可能會被阻止
  • window.close() 關(guān)閉當(dāng)前窗口

window下的對象

  • window.navigator 瀏覽器信息

    • userAgent 用戶代理信息
  • window.location 地址欄信息

    • href 完整的地址(讀/寫)
    • search 地址欄查詢信息(問號到#號之間的所有內(nèi)容)
    • hash #之后的字符(錨點(diǎn))
      • onhashchange hash發(fā)生改變的時(shí)候
  • window.screen 顯示器信息

    • scroll 滾動條

      //獲取可視區(qū)和整個(gè)文檔的高度
        window.innerWidth,window.innerHeight //可視區(qū)
        document.documentElement.clientHeight //可視區(qū)
        document.body.clientHeight//整個(gè)文檔高度
        document.documentElement.scrollHeight//文檔高度
      window.onscroll = function(){ //滾動條滾動
          //滾動條滾動距離(滾動距離)
          console.log(document.documentElement.scrollTop,document.documentElement.scrollLeft);
            //chrome下無效
          console.log(document.body.scrollTop,document.body.scrollLeft);
            // 火狐下無效  IE整體不識別
          console.log(window.scrollY,window.scrollX);//IE整體不識別
          console.log(window.pageYOffset,window.pageXOffset);//IE8及以下不識別
          /*
              IE9-IE11不識別 2,3
              IE8一下只識別 1
          */
      }
      **
        兼容不同瀏覽器
        var scrollY = document.documentElement.scrollTop||document.body.scrollTop;
      ** 
      
      • window.scrollTo(x,y) 設(shè)置滾動條距離
  • window.history 瀏覽器歷史記錄

    • history.back(); 返回歷史記錄的上一頁
    • history.forward(); 進(jìn)入歷史記錄的下一頁
    • history.go(nub); 進(jìn)入具體某一頁
最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
平臺聲明:文章內(nèi)容(如有圖片或視頻亦包括在內(nèi))由作者上傳并發(fā)布,文章內(nèi)容僅代表作者本人觀點(diǎn),簡書系信息發(fā)布平臺,僅提供信息存儲服務(wù)。
  • 序言:七十年代末,一起剝皮案震驚了整個(gè)濱河市,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖,帶你破解...
    沈念sama閱讀 228,345評論 6 531
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件,死亡現(xiàn)場離奇詭異,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī),發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 98,494評論 3 416
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人,你說我怎么就攤上這事。” “怎么了?”我有些...
    開封第一講書人閱讀 176,283評論 0 374
  • 文/不壞的土叔 我叫張陵,是天一觀的道長。 經(jīng)常有香客問我,道長,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 62,953評論 1 309
  • 正文 為了忘掉前任,我火速辦了婚禮,結(jié)果婚禮上,老公的妹妹穿的比我還像新娘。我一直安慰自己,他們只是感情好,可當(dāng)我...
    茶點(diǎn)故事閱讀 71,714評論 6 410
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著,像睡著了一般。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 55,186評論 1 324
  • 那天,我揣著相機(jī)與錄音,去河邊找鬼。 笑死,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播,決...
    沈念sama閱讀 43,255評論 3 441
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 42,410評論 0 288
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎,沒想到半個(gè)月后,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 48,940評論 1 335
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 40,776評論 3 354
  • 正文 我和宋清朗相戀三年,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點(diǎn)故事閱讀 42,976評論 1 369
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情,我是刑警寧澤,帶...
    沈念sama閱讀 38,518評論 5 359
  • 正文 年R本政府宣布,位于F島的核電站,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 44,210評論 3 347
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 34,642評論 0 26
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 35,878評論 1 286
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留,地道東北人。 一個(gè)月前我還...
    沈念sama閱讀 51,654評論 3 391
  • 正文 我出身青樓,卻偏偏與公主長得像,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 47,958評論 2 373

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

  • 什么是 BOM ? 1.瀏覽器對象模型 Browser Object Model 2.BOM的核心對象是windo...
    WeekOne閱讀 420評論 0 2
  • 第一章 1.什么是DOM DOM: Document Object Model(文檔對象模型) 是JavaScri...
    fastwe閱讀 820評論 0 0
  • ??DOM(文檔對象模型)是針對 HTML 和 XML 文檔的一個(gè) API(應(yīng)用程序編程接口)。 ??DOM 描繪...
    霜天曉閱讀 3,674評論 0 7
  • 一、JS前言 (1)認(rèn)識JS 也許你已經(jīng)了解HTML標(biāo)記(也稱為結(jié)構(gòu)),知道了CSS樣式(也稱為表示),會使用HT...
    凜0_0閱讀 2,786評論 0 8
  • 收集于網(wǎng)絡(luò),特此整理。 多看看API,總是沒壞處~ 一、節(jié)點(diǎn) 1.1 節(jié)點(diǎn)屬性 Node.nodeName //...
    前端程序猿阿旭閱讀 5,400評論 1 1