欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

JavaScript之DOM_動力節(jié)點Java學院整理

 更新時間:2017年07月03日 10:24:53   作者:liaoxuefeng  
由于HTML文檔被瀏覽器解析后就是一棵DOM樹,要改變HTML的結(jié)構(gòu),就需要通過JavaScript來操作DOM。始終記住DOM是一個樹形結(jié)構(gòu)。

由于HTML文檔被瀏覽器解析后就是一棵DOM樹,要改變HTML的結(jié)構(gòu),就需要通過JavaScript來操作DOM。
始終記住DOM是一個樹形結(jié)構(gòu)。操作一個DOM節(jié)點實際上就是這么幾個操作:

  1. 更新:更新該DOM節(jié)點的內(nèi)容,相當于更新了該DOM節(jié)點表示的HTML的內(nèi)容;
  2. 遍歷:遍歷該DOM節(jié)點下的子節(jié)點,以便進行進一步操作;
  3. 添加:在該DOM節(jié)點下新增一個子節(jié)點,相當于動態(tài)增加了一個HTML節(jié)點;
  4. 刪除:將該節(jié)點從HTML中刪除,相當于刪掉了該DOM節(jié)點的內(nèi)容以及它包含的所有子節(jié)點。

在操作一個DOM節(jié)點前,我們需要通過各種方式先拿到這個DOM節(jié)點。最常用的方法是document.getElementById()document.getElementsByTagName(),以及CSS選擇器document.getElementsByClassName() 。

由于ID在HTML文檔中是唯一的,所以document.getElementById()可以直接定位唯一的一個DOM節(jié)點。

document.getElementsByTagName()document.getElementsByClassName()總是返回一組DOM節(jié)點。要精確地選擇DOM,可以先定位父節(jié)點,再從父節(jié)點開始選擇,以縮小范圍。

例如:

// 返回ID為'test'的節(jié)點:
var test = document.getElementById('test');

// 先定位ID為'test-table'的節(jié)點,再返回其內(nèi)部所有tr節(jié)點:
var trs = document.getElementById('test-table').getElementsByTagName('tr');

// 先定位ID為'test-div'的節(jié)點,再返回其內(nèi)部所有class包含red的節(jié)點:
var reds = document.getElementById('test-div').getElementsByClassName('red');

// 獲取節(jié)點test下的所有直屬子節(jié)點:
var cs = test.children;

// 獲取節(jié)點test下第一個、最后一個子節(jié)點:
var first = test.firstElementChild;
var last = test.lastElementChild;

第二種方法是使用querySelector()querySelectorAll(),需要了解selector語法,然后使用條件來獲取節(jié)點,更加方便:

// 通過querySelector獲取ID為q1的節(jié)點:
var q1 = document.querySelector('#q1');

// 通過querySelectorAll獲取q1節(jié)點內(nèi)的符合條件的所有節(jié)點:
var ps = q1.querySelectorAll('div.highlighted > p');

注意:低版本的IE<8不支持querySelectorquerySelectorAll。IE8僅有限支持。

嚴格地講,我們這里的DOM節(jié)點是指Element,但是DOM節(jié)點實際上是Node,在HTML中,Node包括Element、Comment、CDATA_SECTION等很多種,以及根節(jié)點Document類型,但是,絕大多數(shù)時候我們只關(guān)心Element,也就是實際控制頁面結(jié)構(gòu)的Node,其他類型的Node忽略即可。根節(jié)點Document已經(jīng)自動綁定為全局變量document。

練習

如下的HTML結(jié)構(gòu):

JavaScript
Java
Python
Ruby
Swift
Scheme
Haskell

<!-- HTML結(jié)構(gòu) -->
<div id="test-div">
<div class="c-red">
  <p id="test-p">JavaScript</p>
  <p>Java</p>
 </div>
 <div class="c-red c-green">
  <p>Python</p>
  <p>Ruby</p>
  <p>Swift</p>
 </div>
 <div class="c-green">
  <p>Scheme</p>
  <p>Haskell</p>
 </div>
</div>

請選擇出指定條件的節(jié)點:

// 選擇<p>JavaScript</p>:
var js = ???;
// 選擇<p>Python</p>,<p>Ruby</p>,<p>Swift</p>:
var arr = ???;
// 選擇<p>Haskell</p>:
var haskell = ???;

相關(guān)文章

最新評論