search
HomeWeb Front-endJS TutorialDiscuss in detail the basic properties of DOM in javascript_javascript skills

Structure and content attributes

nodeType

All nodes have types, and there are a total of 12 types of nodes.

Copy code The code is as follows:

interface Node {
// NodeType
const unsigned short ELEMENT_NODE = 1;
const unsigned short ATTRIBUTE_NODE = 2;
const unsigned short TEXT_NODE = 3;
const unsigned short CDATA_SECTION_NODE = 4;
const unsigned short ENTITY_REFERENCE_NODE = 5;
const unsigned short ENTITY_NODE = 6;
const unsigned short PROCESSING_INSTRUCTION_NODE = 7;
const unsigned short COMMENT_NODE = 8;
const unsigned short DOCUMENT_NODE = 9;
const unsigned short DOCUMENT_TYPE_NODE = 10;
const unsigned short DOCUMENT_FRAGMENT_NODE = 11;
const unsigned short NOTATION_NODE = 12;
...
}

The two most important nodes are the element node (1) and the text node (3). The rest are rarely used.
For example, when listing all child element nodes, we can iterate over it and use childNodes[i].nodeType != 1 to detect.
The following is the implementation code:

Copy code The code is as follows:


Allowed readers:


  • John

  • Bob



<script> <br /> var childNodes = document.body.childNodes<br /> for(var i=0; i<childNodes.length; i ) {<br /> if (childNodes[i].nodeType != 1) continue<br /> alert(childNodes[i])<br /> }<br /> </script>

*Thinking
What will the following code prompt:

Copy code The code is as follows:




<script><br /> alert(document.body.lastChild.nodeType)<br /> </script>


nodeName, tagName

Both nodeName and tagName contain the name of the node.
For document.body

alert( document.body.nodeName ) // BODY
All nodeNames in HTML will be capitalized.

When nodeName is not capitalized
This situation is relatively rare, if you are curious you can read below.
As you probably already know, browsers have two ways of parsing: HTML mode and __XML mode. Usually the HTML schema is used, but when the XMLHttpRequest__ technology is used to obtain an XML document, the XML schema is used.
XML mode is also used in Firefox when the Content-Type of an XHTML document is set to xmlish.
Node names will be preserved in __XML schema, so body or bOdY may appear.
Therefore, if XML is loaded from the server into an HTML document via the XMLHttpRequest__ technology, the node name will be preserved.

NodeName and __tagName__ are the same for elements.
But the nodeName attribute also exists in non-element nodes, and it has a special value in these nodes:

alert(document.nodeName) // #document
Most node types do not have a tagName attribute, and the tagName of annotation nodes in IE is !.
Therefore, nodeName is generally more meaningful than tagName. But tagName is like a simplified version, so you can use it when you are only dealing with element nodes.

innerHTML

innerHTML is part of the HTML5 standard, please see the link for details
It allows textual access to node content. The following example will output all the contents of document.body and replace it with the new content.

Copy code The code is as follows:


The paragraph


And a div

<script><br /> alert( document.body.innerHTML ) // read current contents<br /> Document.body.innerHTML = 'Yaaahooo!' // replace contents<br /> </script>

innerHTML will contain valid HTML. But browsers can also parse malformed HTML.
innerHTML can be used in any element node. It's very, very useful.

innerHTML pitFalls

innerHTML is not as simple as it looks. It has some traps that await newbies, and sometimes even experienced programmers cannot avoid them.

The innerHTML of the __table__ node in IE is read-only
In IE, innerHTML in COL, COLGROUP, FRAMESET, HEAD, HTML, STYLE, TABLE, TBODY, TFOOT, THEAD, TITLE, TR and other elements is read-only.
Except for TD, all innerHTML tags in the table tag in IE are read-only.

innerHTML cannot be appended
Judging from the composition of the statement, innerHTML can perform append operations, such as:

chatDiv.innerHTML = "

Hi Discuss in detail the basic properties of DOM in javascript_javascript skills !
"
chatDiv.innerHTML = "How you doing?"
But what actually happened:

1. Old content is cleared

2. The new content is parsed and inserted. The content is not appended, it is regenerated.

Therefore, all pictures and other resources will be reloaded after the = operation, including smile.gif.

Fortunately, there are other ways to update content that do not use innerHTML and therefore do not have the problems mentioned above.

nodeValue

innerHTML is only valid for element nodes.
For other types of nodes, they use the nodeValue attribute to obtain content. The following example shows how it works on text nodes and comment nodes.

Copy code The code is as follows:


The text

<script><br /> for(var i=0; i<document.body.childNodes.length; i ) {<br /> alert(document.body.childNodes[i].nodeValue)<br /> }<br /> </script>

위 예에서는 빈 노드로 인해 일부 경고가 비어 있습니다. SCRIPT 노드의 경우 nodeValue === null입니다. SCRIPT가 요소 노드이기 때문입니다. 요소 노드의 경우 innerHTML을 사용합니다.

요약

노드 유형
 노드 유형. 가장 중요한 것은 요소 노드가 1이고 텍스트 노드가 3이며 읽기 전용이라는 것입니다.
노드이름/태그이름
  라벨 이름은 대문자입니다. 요소가 아닌 노드의 경우 nodeName에는 읽기 전용인 특수 값도 있습니다.
내부HTML
 요소 노드의 내용, 쓰기 가능.
노드값
 쓰기 가능한 텍스트 노드의 콘텐츠입니다.
DOM 노드에는 유형에 따라 다른 속성이 있습니다. 예를 들어 INPUT 태그에는 value 및 __checked__ 속성이 있습니다. 속성에는 href 등이 있습니다.

위 내용은 이 글의 전체 내용입니다. 모두 마음에 드셨으면 좋겠습니다.

Statement
The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn
From Websites to Apps: The Diverse Applications of JavaScriptFrom Websites to Apps: The Diverse Applications of JavaScriptApr 22, 2025 am 12:02 AM

JavaScript is widely used in websites, mobile applications, desktop applications and server-side programming. 1) In website development, JavaScript operates DOM together with HTML and CSS to achieve dynamic effects and supports frameworks such as jQuery and React. 2) Through ReactNative and Ionic, JavaScript is used to develop cross-platform mobile applications. 3) The Electron framework enables JavaScript to build desktop applications. 4) Node.js allows JavaScript to run on the server side and supports high concurrent requests.

Python vs. JavaScript: Use Cases and Applications ComparedPython vs. JavaScript: Use Cases and Applications ComparedApr 21, 2025 am 12:01 AM

Python is more suitable for data science and automation, while JavaScript is more suitable for front-end and full-stack development. 1. Python performs well in data science and machine learning, using libraries such as NumPy and Pandas for data processing and modeling. 2. Python is concise and efficient in automation and scripting. 3. JavaScript is indispensable in front-end development and is used to build dynamic web pages and single-page applications. 4. JavaScript plays a role in back-end development through Node.js and supports full-stack development.

The Role of C/C   in JavaScript Interpreters and CompilersThe Role of C/C in JavaScript Interpreters and CompilersApr 20, 2025 am 12:01 AM

C and C play a vital role in the JavaScript engine, mainly used to implement interpreters and JIT compilers. 1) C is used to parse JavaScript source code and generate an abstract syntax tree. 2) C is responsible for generating and executing bytecode. 3) C implements the JIT compiler, optimizes and compiles hot-spot code at runtime, and significantly improves the execution efficiency of JavaScript.

JavaScript in Action: Real-World Examples and ProjectsJavaScript in Action: Real-World Examples and ProjectsApr 19, 2025 am 12:13 AM

JavaScript's application in the real world includes front-end and back-end development. 1) Display front-end applications by building a TODO list application, involving DOM operations and event processing. 2) Build RESTfulAPI through Node.js and Express to demonstrate back-end applications.

JavaScript and the Web: Core Functionality and Use CasesJavaScript and the Web: Core Functionality and Use CasesApr 18, 2025 am 12:19 AM

The main uses of JavaScript in web development include client interaction, form verification and asynchronous communication. 1) Dynamic content update and user interaction through DOM operations; 2) Client verification is carried out before the user submits data to improve the user experience; 3) Refreshless communication with the server is achieved through AJAX technology.

Understanding the JavaScript Engine: Implementation DetailsUnderstanding the JavaScript Engine: Implementation DetailsApr 17, 2025 am 12:05 AM

Understanding how JavaScript engine works internally is important to developers because it helps write more efficient code and understand performance bottlenecks and optimization strategies. 1) The engine's workflow includes three stages: parsing, compiling and execution; 2) During the execution process, the engine will perform dynamic optimization, such as inline cache and hidden classes; 3) Best practices include avoiding global variables, optimizing loops, using const and lets, and avoiding excessive use of closures.

Python vs. JavaScript: The Learning Curve and Ease of UsePython vs. JavaScript: The Learning Curve and Ease of UseApr 16, 2025 am 12:12 AM

Python is more suitable for beginners, with a smooth learning curve and concise syntax; JavaScript is suitable for front-end development, with a steep learning curve and flexible syntax. 1. Python syntax is intuitive and suitable for data science and back-end development. 2. JavaScript is flexible and widely used in front-end and server-side programming.

Python vs. JavaScript: Community, Libraries, and ResourcesPython vs. JavaScript: Community, Libraries, and ResourcesApr 15, 2025 am 12:16 AM

Python and JavaScript have their own advantages and disadvantages in terms of community, libraries and resources. 1) The Python community is friendly and suitable for beginners, but the front-end development resources are not as rich as JavaScript. 2) Python is powerful in data science and machine learning libraries, while JavaScript is better in front-end development libraries and frameworks. 3) Both have rich learning resources, but Python is suitable for starting with official documents, while JavaScript is better with MDNWebDocs. The choice should be based on project needs and personal interests.

See all articles

Hot AI Tools

Undresser.AI Undress

Undresser.AI Undress

AI-powered app for creating realistic nude photos

AI Clothes Remover

AI Clothes Remover

Online AI tool for removing clothes from photos.

Undress AI Tool

Undress AI Tool

Undress images for free

Clothoff.io

Clothoff.io

AI clothes remover

Video Face Swap

Video Face Swap

Swap faces in any video effortlessly with our completely free AI face swap tool!

Hot Tools

SecLists

SecLists

SecLists is the ultimate security tester's companion. It is a collection of various types of lists that are frequently used during security assessments, all in one place. SecLists helps make security testing more efficient and productive by conveniently providing all the lists a security tester might need. List types include usernames, passwords, URLs, fuzzing payloads, sensitive data patterns, web shells, and more. The tester can simply pull this repository onto a new test machine and he will have access to every type of list he needs.

WebStorm Mac version

WebStorm Mac version

Useful JavaScript development tools

Atom editor mac version download

Atom editor mac version download

The most popular open source editor

EditPlus Chinese cracked version

EditPlus Chinese cracked version

Small size, syntax highlighting, does not support code prompt function

DVWA

DVWA

Damn Vulnerable Web App (DVWA) is a PHP/MySQL web application that is very vulnerable. Its main goals are to be an aid for security professionals to test their skills and tools in a legal environment, to help web developers better understand the process of securing web applications, and to help teachers/students teach/learn in a classroom environment Web application security. The goal of DVWA is to practice some of the most common web vulnerabilities through a simple and straightforward interface, with varying degrees of difficulty. Please note that this software