ES6 - HTML DOM

Mọi trang web đều nằm bên trong cửa sổ trình duyệt, có thể được coi là một đối tượng.

A document objectđại diện cho tài liệu HTML được hiển thị trong cửa sổ đó. Đối tượng tài liệu có nhiều thuộc tính tham chiếu đến các đối tượng khác cho phép truy cập và sửa đổi nội dung tài liệu.

Cách nội dung tài liệu được truy cập và sửa đổi được gọi là Document Object Model, hoặc là DOM. Các đối tượng được tổ chức theo một hệ thống phân cấp. Cấu trúc phân cấp này áp dụng cho việc tổ chức các đối tượng trong một tài liệu web.

Sau đây là một hệ thống phân cấp đơn giản của một vài đối tượng quan trọng:

Có một số DOM đang tồn tại. Các phần sau đây giải thích chi tiết từng DOM này và mô tả cách bạn có thể sử dụng chúng để truy cập và sửa đổi nội dung tài liệu.

  • The Legacy DOM- Đây là mô hình đã được giới thiệu trong các phiên bản đầu tiên của ngôn ngữ JavaScript. Nó được hỗ trợ tốt bởi tất cả các trình duyệt, nhưng chỉ cho phép truy cập vào một số phần chính của tài liệu, chẳng hạn như biểu mẫu, thành phần biểu mẫu và hình ảnh.

  • The W3C DOM- Mô hình đối tượng tài liệu này cho phép truy cập và sửa đổi tất cả nội dung tài liệu và được tiêu chuẩn hóa bởi World Wide Web Consortium (W3C). Mô hình này được hỗ trợ bởi hầu hết các trình duyệt hiện đại.

  • The IE4 DOM- Mô hình đối tượng tài liệu này đã được giới thiệu trong Phiên bản 4 của trình duyệt Internet Explorer của Microsoft. IE 5 và các phiên bản mới hơn bao gồm hỗ trợ cho hầu hết các tính năng cơ bản của W3C DOM.

DOM kế thừa

Đây là mô hình đã được giới thiệu trong các phiên bản đầu tiên của ngôn ngữ JavaScript. Nó được hỗ trợ tốt bởi tất cả các trình duyệt, nhưng chỉ cho phép truy cập vào một số phần chính của tài liệu, chẳng hạn như biểu mẫu, thành phần biểu mẫu và hình ảnh.

Mô hình này cung cấp một số thuộc tính chỉ đọc, chẳng hạn như tiêu đề, URL và lastModified cung cấp thông tin về toàn bộ tài liệu. Ngoài ra, có nhiều phương thức khác nhau được cung cấp bởi mô hình này có thể được sử dụng để đặt và lấy các giá trị thuộc tính tài liệu.

Thuộc tính tài liệu trong DOM kế thừa

Sau đây là danh sách các thuộc tính tài liệu có thể được truy cập bằng Legacy DOM.

Sr.No Kê khai tài sản
1

alinkColor

Không được chấp nhận - Một chuỗi chỉ định màu của các liên kết được kích hoạt.

Example : document.alinkColor

2

anchors[ ]

Một mảng các đối tượng neo, một đối tượng cho mỗi neo xuất hiện trong tài liệu.

Example : document.anchors [0], document.anchors [1], v.v.

3

applets[ ]

Một mảng các đối tượng applet, một cho mỗi applet xuất hiện trong tài liệu.

Example : document.applets [0], document.applets [1], v.v.

4

bgColor

Không được tán thành - Một chuỗi chỉ định màu nền của tài liệu.

Example : document.bgColor

5

Cookie

Thuộc tính có giá trị chuỗi với hành vi đặc biệt cho phép các cookie được liên kết với tài liệu này được truy vấn và thiết lập.

Example : document.cookie

6

Domain

Một chuỗi chỉ định miền Internet mà tài liệu đến. Được sử dụng cho mục đích bảo mật.

Example : document.domain

7

embeds[ ]

Một mảng các đối tượng đại diện cho dữ liệu được nhúng trong tài liệu với thẻ <embed>. Từ đồng nghĩa với plugin []. Một số plugin và điều khiển ActiveX có thể được kiểm soát bằng mã JavaScript.

Example : document.embeds [0], document.embeds [1], v.v.

số 8

fgColor

Một chuỗi chỉ định màu văn bản mặc định cho tài liệu.

Example : document.fgColor

9

forms[ ]

Một mảng các đối tượng biểu mẫu, một đối tượng cho mỗi biểu mẫu HTML xuất hiện trong tài liệu.

Example : document.forms [0], document.forms [1], v.v.

10

images[ ]

Một mảng các đối tượng biểu mẫu, một đối tượng cho mỗi biểu mẫu HTML xuất hiện trong tài liệu với thẻ HTML <img>.

Example : document.forms [0], document.forms [1], v.v.

11

lastModified

Chuỗi chỉ đọc chỉ định ngày thay đổi gần đây nhất đối với tài liệu.

Example : document.lastModified

12

linkColor

Không được tán thành - Một chuỗi chỉ định màu của các liên kết không được truy cập.

Example : document.linkColor

13

links[ ]

Nó là một mảng liên kết tài liệu.

Example : document.links [0], document.links [1], v.v.

14

Location

URL của tài liệu. Không được chấp nhận có lợi cho thuộc tính URL.

Example : document.location

15

plugins[ ]

Một từ đồng nghĩa với nhúng []

Example : document.plugins [0], document.plugins [1], v.v.

16

Referrer

Chuỗi chỉ đọc chứa URL của tài liệu, nếu có, từ đó tài liệu hiện tại được liên kết.

Example : document.referrer

17

Title

Nội dung văn bản của thẻ <title>.

Example : tiêu đề tài liệu

18

URL

Một chuỗi chỉ đọc chỉ định URL của tài liệu.

Example : document.URL

19

vlinkColor

Không được tán thành - Một chuỗi chỉ định màu của các liên kết đã truy cập.

Example : document.vlinkColor

Phương thức tài liệu trong DOM kế thừa

Sau đây là danh sách các phương pháp được hỗ trợ bởi Legacy DOM.

Sr.No Kê khai tài sản
1

clear( )

Không được dùng nữa - Xóa nội dung của tài liệu và không trả về.

Example : document.clear ()

2

close( )

Đóng luồng tài liệu được mở bằng phương thức open () và không trả về gì.

3

open( )

Xóa nội dung tài liệu hiện có và mở một luồng mà nội dung tài liệu mới có thể được viết. Không trả lại gì.

Example : document.open ()

4

write( value, ...)

Chèn chuỗi hoặc các chuỗi đã chỉ định vào tài liệu hiện đang được phân tích cú pháp hoặc nối vào tài liệu được mở bằng open (). Không trả lại gì.

Example : document.write (value, ...)

5

writeln( value, ...)

Giống nhau để write (), ngoại trừ việc nó thêm một ký tự dòng mới vào đầu ra. Không trả lại gì.

Example : document.writeln (giá trị, ...)

Chúng tôi có thể định vị bất kỳ phần tử HTML nào trong bất kỳ tài liệu HTML nào bằng HTML DOM. Ví dụ: nếu một tài liệu web chứa một phần tử biểu mẫu, thì khi sử dụng JavaScript, chúng ta có thể gọi nó là document.forms [0]. Nếu tài liệu Web của bạn bao gồm hai phần tử biểu mẫu, biểu mẫu đầu tiên được gọi là document.forms [0] và thứ hai là document.forms [1].

Bằng cách sử dụng hệ thống phân cấp và thuộc tính đã cho ở trên, chúng ta có thể truy cập phần tử biểu mẫu đầu tiên bằng document.forms [0] .elements [0], v.v.

Thí dụ

Sau đây là một ví dụ để truy cập thuộc tính tài liệu bằng phương pháp Legacy DOM.

<html> 
   <head> 
      <title> Document Title </title> 
      
      <script type = "text/javascript"> 
         <!--  
            function myFunc() {  
               var ret = document.title;  
               alert("Document Title : " + ret );  
               var ret = document.URL;  
               alert("Document URL : " + ret );  
               var ret = document.forms[0];  
               alert("Document First Form : " + ret );  
               var ret = document.forms[0].elements[1];  
               alert("Second element : " + ret );  
            } //
         --> 
      </script> 
   </head> 
   
   <body> 
      <h1 id = "title">This is main title</h1> 
      <p>Click the following to see the result:</p> 
      
      <form name = "FirstForm">
         <input type = "button" value = "Click Me" onclick = "myFunc();" /> 
         <input type = "button" value = "Cancel"> 
      </form> 

      <form name = "SecondForm"> 
         <input type = "button" value = "Don't ClickMe"/> 
      </form> 
   </body> 
   
</html>

Đầu ra

Kết quả sau được hiển thị khi thực hiện thành công đoạn mã trên.

Note- Ví dụ này trả về các đối tượng cho các biểu mẫu và phần tử. Chúng tôi sẽ phải truy cập các giá trị của chúng bằng cách sử dụng các thuộc tính đối tượng không được thảo luận trong hướng dẫn này.