自拍偷在线精品自拍偷,亚洲欧美中文日韩v在线观看不卡

一篇文章帶你了解 JavaScript htmldom 導(dǎo)航

開發(fā) 前端
使用HTML DOM,可以使用節(jié)點(diǎn)關(guān)系來導(dǎo)航"節(jié)點(diǎn)樹"。

使用HTML DOM,可以使用節(jié)點(diǎn)關(guān)系來導(dǎo)航"節(jié)點(diǎn)樹"。

一、DOM 節(jié)點(diǎn)

 在一個(gè)HTML文檔都是一個(gè)節(jié)點(diǎn),The entire document is a document node 每個(gè)HTML元素是元素節(jié)點(diǎn) 在HTML元素的文本是文本節(jié)點(diǎn) 每一個(gè)HTML屬性是一個(gè)屬性節(jié)點(diǎn) 所有注釋都是注釋節(jié)點(diǎn)。

使用HTML DOM, 在節(jié)點(diǎn)樹的所有節(jié)點(diǎn)可以通過JavaScript訪問。可以創(chuàng)建新節(jié)點(diǎn),并可以修改或刪除所有節(jié)點(diǎn)。

1. 節(jié)點(diǎn)關(guān)系

節(jié)點(diǎn)樹中的節(jié)點(diǎn)彼此具有層次關(guān)系。

2. 子節(jié)點(diǎn)和節(jié)點(diǎn)值

在DOM處理中常見的錯(cuò)誤就是認(rèn)為一個(gè)元素節(jié)點(diǎn)包含文本。

<title id="demo">DOM Tutorial</title>

元素節(jié)點(diǎn)<title> (在上面的實(shí)例中) 不包含文本。

它包含有值的文本節(jié)點(diǎn) "DOM Tutorial"。

該文本節(jié)點(diǎn)的值可以通過節(jié)點(diǎn)的innerHTML屬性訪問。

var myTitle = document.getElementById("demo").innerHTML;

訪問innerHTML屬性訪問和訪問第一個(gè)子節(jié)點(diǎn)值相同:

var myTitle = document.getElementById("demo").firstChild.nodeValue;

訪問第一個(gè)子節(jié)點(diǎn)也可以這樣做:

var myTitle = document.getElementById("demo").childNodes[0].nodeValue;

實(shí)例1:

查詢<h1>元素的文本,并且拷貝它到<p>元素

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>項(xiàng)目</title>
</head>
<body style="background-color: aqua;">


<h1 id="id01">My First Page</h1>
<p id="id02"></p>


<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").innerHTML;
</script>


</body>
</html>

實(shí)例2:

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>項(xiàng)目</title>
</head>
<body style="background-color: aqua;">


   <h1 id="id01">My First Page</h1>
    <p id="id02"></p>


 <script>
  document.getElementById("id02").innerHTML =         document.getElementById("id01").firstChild.nodeValue;
</script>


</body>
</html>

實(shí)例3 :

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>項(xiàng)目</title>
</head>
<body style="background-color: aqua;">
   <h1 id="id01">My First Page</h1>
    <p id="id02">Hello!</p>


   <script>
    document.getElementById("id02").innerHTML =       document.getElementById("id01").childNodes[0].nodeValue;
</script>


</body>
</html>

二、DOM 根節(jié)點(diǎn)

有兩個(gè)特殊屬性允許訪問完整文檔:

document.body - 文檔主體

<!DOCTYPE html>
<html lang="en">
<head>
<meta charset="UTF-8">
<title>項(xiàng)目</title>
</head>
<body style="background-color: aqua;">


<h1 id="id01">我的第一個(gè)頁面</h1>
<p id="id02"></p>


<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").childNodes[0].nodeValue;
</script>




</body>
</html>

document.documentElement - 完整的文檔

<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8">
    <title>項(xiàng)目</title>
  </head>
  <body style="background-color: aqua;">
  <p>Hello World!</p>
  <div>
  <p>The DOM is very useful!</p>
   <p>This example demonstrates the <b>document.documentElement</b> property.</p>
  </div>


  <script>
    alert(document.documentElement.innerHTML);
</script>


</body>
</html>

1. nodeName 屬性

nodeName屬性指定一個(gè)節(jié)點(diǎn)的名稱,nodeName 是只讀的。

  • nodeName 是只讀的。
  • nodeName 一個(gè)元素節(jié)點(diǎn)的節(jié)點(diǎn)名稱和標(biāo)簽名稱相同。
  • 一個(gè)屬性節(jié)點(diǎn)的節(jié)點(diǎn)名稱是屬性名。
  • 一個(gè)文本節(jié)點(diǎn)的nodeName總是 #text。
  • 文檔的節(jié)點(diǎn)名稱總是 #document。
<h1 id="id01">My First Page</h1>
<p id="id02"></p>


<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").nodeName;
</script>

注意:

nodeName總是包含HTML元素的大寫標(biāo)簽名稱。

2. nodeValue 屬性

nodeValue 屬性指定節(jié)點(diǎn)的值。素節(jié)點(diǎn)的節(jié)點(diǎn)值是 undefined,文本節(jié)點(diǎn)的節(jié)點(diǎn)是文本本身,屬性節(jié)點(diǎn)的節(jié)點(diǎn)值是屬性值。

3. nodeType 屬性

nodeType 屬性返回節(jié)點(diǎn)類型. nodeType 是只讀的。

<script>
document.getElementById("id02").innerHTML = document.getElementById("id01").nodeType;
</script>

三、總結(jié)

本文基于JavaScript,介紹了頁面上htmldom 導(dǎo)航的節(jié)點(diǎn)。節(jié)點(diǎn)和節(jié)點(diǎn)之間的關(guān)系,采用生動(dòng)的比喻進(jìn)行講解。以及根節(jié)點(diǎn)的屬性進(jìn)行了詳細(xì)講解。通過豐富的案例,運(yùn)行效果圖的展示。希望能幫助讀者更好的學(xué)習(xí)。

責(zé)任編輯:華軒 來源: 前端進(jìn)階學(xué)習(xí)交流
相關(guān)推薦

2021-11-16 07:54:33

JavaScript導(dǎo)航HTML

2020-10-20 15:37:48

了解JavaScrip

2021-11-26 11:10:07

JavaScript 節(jié)點(diǎn)導(dǎo)航

2023-06-01 17:10:12

HTMLJavaScript

2021-05-07 14:17:01

JavaScript元素網(wǎng)頁

2025-02-25 11:12:53

JavaScriptHTML元素CSS

2023-07-30 15:18:54

JavaScript屬性

2021-01-26 23:46:32

JavaScript數(shù)據(jù)結(jié)構(gòu)前端

2021-03-09 14:04:01

JavaScriptCookie數(shù)據(jù)

2021-06-24 09:05:08

JavaScript日期前端

2023-09-06 14:57:46

JavaScript編程語言

2024-01-30 13:47:45

2024-04-19 14:23:52

SwitchJavaScript開發(fā)

2021-03-05 18:04:15

JavaScript循環(huán)代碼

2021-05-18 08:30:42

JavaScript 前端JavaScript時(shí)

2020-11-10 10:48:10

JavaScript屬性對(duì)象

2021-01-29 18:41:16

JavaScript函數(shù)語法

2021-02-02 18:39:05

JavaScript

2021-06-04 09:56:01

JavaScript 前端switch

2024-05-17 16:22:25

JavaScript
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)