HTML Là Gì? - Sưu Tầm
Có thể bạn quan tâm
Chuyển đến nội dung chính
Chúng ta có thể thấy tất cả các thẻ HTML sẽ được quản lý trong đối tượng document (DOM), thẻ cao nhất là thẻ html, tiếp đến là phân nhánh body và head. Bên trong head thì có những thẻ như style, title,... và bên trong body chứa bất kì một thẻ nào đó là thành phần của HTML. Như vậy ta có thể hiểu trong Javascript để thao tác được với các thẻ HTML ta phải thông qua đối tượng documnent (DOM). Với DOM, JavaScript được tất cả sức mạnh cần thiết để tạo ra HTML động:
Nói tóm lại, attribute là thuộc tính của các phần tử DOM. Attribute cho biết các đặc điểm của phần tử DOM đó.
Quan hệ giữa các nút
Các trình duyệt hiện đại sau này (Chrome) có hỗ trợ thêm các phương thức truy xuất mạnh mẽ và linh hoạt hơn nhiều, thậm chí hỗ trợ truy xuất theo vùng chọn CSS phức tạp như vùng chọn jQuery (một thư viện Javascript mạnh và đáng dùng để tối ưu hóa hiệu quả công việc cũng như tiết kiệm thời gian).
Những khái niệm cơ bản về DOM - nguồn: https://viblo.asia
HTML là gì?
HTML đã quá quen với lập trình viên, vậy nó được hiểu như thế nào? Như các bạn đã biết HTML là ngôn ngữ đánh dấu siêu văn bản, nó là một XML namespace, hay được hiểu là tập các thẻ XML mà trình duyệt nào cũng có thể đọc được. Chúng ta nhìn vào một file HTML thì nhìn thấy text, còn trình duyệt nhìn vào sẽ thấy cây DOM.DOM là gì?
Thêm một khái niệm nữa, chúng ta thường nghe đến DOM và làm việc với chúng, vậy chúng được hiểu như thế nào?
Chúng ta có thể thấy tất cả các thẻ HTML sẽ được quản lý trong đối tượng document (DOM), thẻ cao nhất là thẻ html, tiếp đến là phân nhánh body và head. Bên trong head thì có những thẻ như style, title,... và bên trong body chứa bất kì một thẻ nào đó là thành phần của HTML. Như vậy ta có thể hiểu trong Javascript để thao tác được với các thẻ HTML ta phải thông qua đối tượng documnent (DOM). Với DOM, JavaScript được tất cả sức mạnh cần thiết để tạo ra HTML động: - JavaScript có thể thay đổi tất cả các phần tử HTML trong trang
- JavaScript có thể thay đổi tất cả các thuộc tính HTML trong trang
- JavaScript có thể thay đổi tất cả các phong cách CSS trong trang
- JavaScript có thể loại bỏ các yếu tố HTML và thuộc tính hiện tại
- JavaScript có thể thêm các yếu tố HTML mới và các thuộc tính
- JavaScript có thể phản ứng với tất cả các sự kiện HTML hiện trong trang
- JavaScript có thể tạo ra các sự kiện HTML mới trong trang
HTML DOM là gì?
HTML DOM là một chuẩn mô hình object và programming interface cho HTML. nó định nghĩa:- HTML elements như là objects
- properties của tất cả HTML elements
- methods để truy cập đến tất cả HTML elements
- events cho tất cả HTML elements
DOM Attributes
Attributes property là một khái niệm của DOM trả về một tập hợp các thuộc tính của nút được chỉ định, như một đối tượng NamedNodeMap. Các nút có thể được truy cập bởi các con số chỉ số, và chỉ số bắt đầu từ 0. Và bằng số chỉ mục là hữu ích cho đi qua tất cả các thành phần của Attributes: Bạn có thể sử dụng các property của đối tượng NamedNodeMap để xác định số lượng các thuộc tính, lặp qua tất cả sau đó bạn có thể tính các nút và trích xuất các thông tin mà bạn muốn. Xét ví dụ sau: <!DOCTYPE html> <html> <body> <p>Click the button to display the name of the button's second attribute (index 1).</p> <button id="myBtn" onclick="myFunction()">Try it</button> <p id="demo"></p> <script> function myFunction() { var x = document.getElementById("myBtn").attributes[1].name; document.getElementById("demo").innerHTML = x; } </script> </body> </html> Kết quả sẽ như sau:
Nói tóm lại, attribute là thuộc tính của các phần tử DOM. Attribute cho biết các đặc điểm của phần tử DOM đó. Property
Property cung cấp thêm thông tin về các thành phần trong HTML, các phần tử DOM được ánh xạ thành các đối tượng Javascript khi ta sử dụng Javascript để thao tác với DOM. var paragraphs = document.getElementsByTagName('P'); // (1) var firstParagraph = paragraphs[0]; // (2) Phần tử <P> đầu tiên của document được ánh xạ thành đối tượng Javascript được trỏ bởi biến firstParagraph, (getElementsByTagName() trả về một cấu trúc dữ liệu tương tự 1 mảng các Node được gọi là NodeList, tức là có thuộc tính length, và truy xuất thông qua chỉ số). Phần tử DOM được ánh xạ thành đối tượng có thuộc tính và phương thức trong Javascript. Thuộc tính của đối tượng Javascript, được gọi là property. Chung quy lại thì:Attribute là thuộc tính các phần tử DOM còn Property là thuộc tính của đối tượng Javascript.**Một vài chú ý nhỏ
- Attribute của DOM element và property của Javascript object tương ứng thì không có quan hệ 1 - 1. Chẳng hạn như attribute class được ánh xạ thành property className và attribute forđược ánh xạ thành htmlFor
- Dùng phương thức getAttribute(name) và setAttribute('name', 'value'). Để thao tác với property để tương tác với attribute, dùng dot notation (element.property = value)
- Attribute value của phần tử <input type="text" value="type to search"/> chính vì vậy thay đổi property không chắc chắn làm thay đổi attribute và ngược lại.
Cây cấu trúc trong DOM
Nút
Đối với HTML DOM, cấu trúc dạng cây gọi là DOM Tree có nghĩa là mọi thành phần đều được xem là 1 nút (node), được biểu diễn trên 1 cây . Các phần tử khác nhau sẽ được phân loại nút khác nhau nhưng quan trọng nhất là 3 loại: nút gốc (document node), nút phần tử (element node), nút văn bản (text node).- Nút gốc: thường được biểu diễn bởi thẻ <html> là thành phần của HTML.
- Nút phần tử: biểu thị cho 1 phần tử HTML.
- Nút văn bản: mỗi đoạn kí tự trong tài liệu HTML, bên trong 1 thẻ HTML đều là 1 nút văn bản. Đó có thể là tên trang web trong thẻ <title>, tên đề mục trong thẻ <h1>, hay một đoạn văn trong thẻ <p>. Ngoài ra còn có nút thuộc tính (attribute node) và nút chú thích (comment node).
Quan hệ giữa các nút - Nút gốc (root document) luôn luôn là nút đầu tiên.
- Tất cả các nút không phải là nút gốc và đều chỉ có 1 nút cha (parent).
- Một nút có thể có một hoặc nhiều con, hoặc cũng có thể không có con nào.
- Những nút anh em (siblings) thì có cùng nút cha.
- Trong các nút anh em (siblings), nút đầu tiên được gọi là anh cả (firstChild) và nút cuối cùng là em út (lastChild).
Thuộc tính và phương thức thường gặp
Các khái niệm này khá là quen thuộc, các bạn có thể tìm trong W3SchoolsTruy xuất DOM
Truy xuất gián tiếp
Mỗi nút trên cây DOM đều có 6 thuộc tính quan hệ để giúp bạn truy xuất gián tiếp theo vị trí của nút:- Node.parentNode: tham chiếu đến nút cha của nút hiện tại, và nút cha này là duy nhất cho mỗi nút. Do đó, nếu bạn cần tìm nguồn gốc sâu xa của 1 nút, bạn phải nối thuộc tình nhiều lần, ví dụ Node.parentNode.parentNode.
- Node.childNodes: tham chiếu đến các nút con trực tiếp của nút hiện tại, và kết quả là 1 mảng các đối tượng. Lưu ý rằng, các nút con không bị phân biệt bởi loại nút, nên kết quả mảng trả về có thể bao gồm nhiều loại nút khác nhau.
- Node.firstChild: tham chiếu đến nút con đầu tiên của nút hiện tại, và tương đương với việc gọi Node.childNodes[0].
- Node.lastChild: tham chiếu đến nút con cuối cùng của nút hiện tại, và tương đương với việc gọi Node.childNodes[Element.childNodes.length-1].
- Node.nextSibling: tham chiếu đến nút anh em nằm liền kề sau với nút hiện tại.
- Node.previousSibling: tham chiếu đến nút anh em nằm liền kề trước với nút hiện tại.
Truy xuất trưc tiếp
Truy xuất trực tiếp sẽ nhanh hơn, và đơn giản hơn khi bạn không cần phải biết nhiều về quan hệ và vị trí của nút. Có 3 phương thức để bạn truy xuất trực tiếp được hỗ trợ ở mọi trình duyệt:- document.getElementById('id_cần_tìm')
- document.getElementsByTagName('div')
- document.getElementsByName('tên_cần_tìm')
Các trình duyệt hiện đại sau này (Chrome) có hỗ trợ thêm các phương thức truy xuất mạnh mẽ và linh hoạt hơn nhiều, thậm chí hỗ trợ truy xuất theo vùng chọn CSS phức tạp như vùng chọn jQuery (một thư viện Javascript mạnh và đáng dùng để tối ưu hóa hiệu quả công việc cũng như tiết kiệm thời gian). - document.querySelector('#id p.class'): truy xuất đến vùng chọn và trả về kết quả tham chiếu đầu tiên.
- document.querySelectorAll('#id p[class^=test]'): tương tự querySelector nhưng trả về mảng các tham chiếu.
- document.getElementsByName('class1 class2'): tham chiếu đến tất cả các nút có thuộc tính className chứa tất cả các tên lớp cần tìm.
Kết luận
Chung quy lại chúng ta đã cùng nhau tìm hiểu các khái niệm cơ bản về DOM và cách thao tác với nó. Đó chỉ là những kiến thức hết sức cơ bản, tuy nhiên bạn cũng có thể thấy DOM quan trọng như thế nào. Nguồn: https://viblo.asia/p/nhung-khai-niem-co-ban-ve-dom-DzVkpoDgenWNhận xét
Đăng nhận xét
Bài đăng phổ biến
Khôi phục phân vùng ổ cứng do ghost nhầm theo Hieuit.net
Link tải phần mềm link Google Drive (tải nhanh): https://drive.google.com/drive/folders/1A-JAxDTXcEcZ-8kWzS9lpZ2BN086Gf5L?usp=sharing Link xem hướng dẫn lấy mã giải nén phần mềm: trên: https://docs.google.com/document/d/1P4Pp2joSl6qAtnjNieoDcU0j7Z1yqUE4/edit?usp=sharing&ouid=112212768248379981623&rtpof=true&sd=true Hôm nay mình sẽ hướng dẫn các bạn khôi phục phân vùng ổ cứng do ghost nhầm, chọn sai lệnh trong recovery bản quyền hệ điều hành trên laptop, xóa nhầm khi thao tác trên các phần mềm phân chia ổ cứng, chạy sai dòng lệnh diskpart. Với tỷ lệ thành công 99% , 1% không thành công là do ổ cứng bị lỗi vật lý (bad sector đoạn chứa Partition Table), do đã dùng các công cụ khác để khôi phục partition nhưng không thành công và đã chia lại ổ cứng. Chỉ với 1 chút sai lầm mà bạn phải trả giá là ổ cứng với một đống dữ liệu quý giá đã “bốc hơi” và chỉ còn thấy 1 ổ đĩa duy nhất. Trong trường hợp này bạn phải bình tĩnh và cẩn thận...Lỗi không attach được Database vào SQL server 2008
Sau mấy lần sao chép file mdf từ máy cơ quan về nhà và ngược lại thỉnh thoảng lại bị lỗi không attach được vào SQL server 2008 với những thông báo lỗi đại loại như " An exception occurred while executing a Transact-SQL statement or batch". Copy file Database cần attach vào đúng thư mục có cấu trúc như ở máy cơ quan thì cũng có lúc được, cũng có lúc không, xét về nguyên tắc thì việc làm trên là vô lý nhưng sự thực là cũng có lúc nó được. Cuối cùng tìm kiếm trên internet thì có người bày cho cách xử lý như sau: - Phân lại quyền truy cập trên hệ thống cho file .mdf và file .ldf + Chuột phải vào file .mdf chọn Properties chọn sang thẻ Security + Click chọn Edit tiếp theo chọn Add => click Advanced... => click Find Now =>tìm đến tài khoản EveryOne rồi click OK => click tiếp Ok sau đó click vào tài khoản EveryOne vừa Add nhìn xuống dưới click chọn vào Full Control => click...CSS tạo hình tam giác
Để có được hình tam giác thì thật đơn giản với các công cụ đồ họa, đơn giản đến mức không cần vẽ mà chỉ cần chèn một hình shape trong hộp công cụ vậy là đã có được hình ảnh trong vài giây, nhưng nếu linh động và không muốn sử dụng hình ảnh bạn vẫn có thể tạo ra nó chỉ với vài thuộc tính CSS đơn giản, điều này sẽ có ích cho việc tạo ra những nút trên web hay ứng dụng làm tooltip. Đầu tiên chúng ta hãy cùng xem xét trường hợp nếu định kiểu đường viền cho một phần tử không mà không quan tâm đến kích thước phần tử đó như đoạn CSS sau: 1 .triangle{ 2 border-color : blue orange red green ; 3 border-style : solid ; 4 border-width : 100px 100px 100px 100px ; 5 height : 0px ; 6 width : 0px ; 7 } Kết quả bạn có được 1 hình vuông được gép lại từ 4 tam giác tương ứng với 4 đường viền đã định kiểu, bây giờ nếu thay kiểu ...Từ khóa » Javascript Cơ Bản Viblo
-
JavaScript Căn Bản - Viblo
-
Cơ Bản Về Javascript - Viblo
-
Viblo - JavaScript Căn Bản "JavaScript (JS) Là Một Ngôn... | Facebook
-
Javascript Căn Bản - Có- | Năm 2022, 2023
-
Ú ớ Khi Phỏng Vấn
-
TypeScript Căn Bản Cho Người Mới Bắt đầu - 2KVN
-
Javascript Co Ban Viblo ❤️❤️❤️ đi- | Năm 2022, 2023
-
20 Câu Hỏi Phỏng Vấn Javascript Dành Cho Intern/Fresher - TopDev
-
Top 7 Bài Viết Viblo đỉnh Nhất 2019 - Sun* News
-
Code Cùng Code Dạo - Tự Học JavaScript Cơ Bản Trong 15 Phút
-
Viblo Learning Mini Event 2022 "TypeScript For Beginner" - AI Design
-
React JS - Cơ Bản Về Redux - Trang Chủ
-
Ý Nghĩa Ra đời Của Viblo - Hàng Hiệu Giá Tốt