In the development of Web applications, especially Web 2.0 programs, it is often necessary to obtain an element in the page and then update the style, content, etc. of the element. How to obtain the elements to be updated is the first problem to be solved. Fortunately, there are many ways to obtain nodes using JavaScript. Here is a brief summary (the following method has been tested in IE7 and Firefox2.0.0.11):
1. Obtain through the top-level document node:
(1) document.getElementById(elementId): This method can accurately obtain the required element through the ID of the node. It is a relatively simple and fast method. If the page contains multiple nodes with the same ID, only the first node will be returned.
Nowadays, many JavaScript libraries such as prototype and Mootools have appeared, which provide a simpler method: $(id), and the parameter is still the id of the node. This method can be regarded as another way of writing document.getElementById(), but the function of $() is more powerful. For specific usage, please refer to their respective API documents.
(2) document.getElementsByName(elementName): This method gets the node by its name. As can be seen from the name, this method returns not a node element, but an array of nodes with the same name. Then, we can loop through a certain attribute of the node to determine whether it is the required node.
For example: In HTML, checkbox and radio use the same name attribute value to identify elements in a group. If we want to get the selected element now, we first get the shuffled element, and then loop to determine whether the checked attribute value of the node is true.
(3) document.getElementsByTagName(tagName): This method obtains the node through its Tag. This method also returns an array. For example: document.getElementsByTagName('A') will return all hyperlink nodes on the page. . Before obtaining the node, the type of the node is generally known, so it is relatively simple to use this method. But the disadvantage is also obvious, that is, the returned array may be very large, which will waste a lot of time. So, is this method useless? Of course not. This method is different from the two above. It is not a proprietary method of the document node and can also be applied to other nodes, which will be mentioned below.
2. Obtain through parent node:
(1) parentObj.firstChild: This method can be used if the node is the first child node of a known node (parentObj). This attribute can be used recursively, that is, it supports the form of parentObj.firstChild.firstChild.firstChild..., so that deeper nodes can be obtained.
(2) parentObj.lastChild: Obviously, this attribute is to get the last child node of the known node (parentObj). Like firstChild, it can also be used recursively.
In use, if we combine the two, we will achieve a more exciting effect, namely: parentObj.firstChild.lastChild.lastChild...
(3) parentObj.childNodes: Get the child node array of a known node, and then find the required node through looping or indexing.
Note: After testing, it was found that on IE7, what is obtained is the array of direct child nodes, while on Firefox2.0.0.11, what is obtained is all child nodes, including the child nodes of the child node.
(4) parentObj.children: Get the direct child node array of a known node.
Note: After testing, on IE7, the effect is the same as childNodes, but Firefox2.0.0.11 does not support it. This is why I use a different style than other methods. Therefore its use is not recommended.
(5) parentObj.getElementsByTagName(tagName): The usage method will not be described in detail. It returns an array of child nodes of the specified value among all child nodes of the known node. For example: parentObj.getElementsByTagName('A') returns all hyperlinks in known child nodes.
3. Obtain through adjacent nodes:
(1) neighborNode.previousSibling: Get the previous node of the known node (neighbourNode). This attribute seems to be recursively used like the previous firstChild and lastChild.
(2) neighborNode.nextSibling: Get the next node of the known node (neighbourNode), also supports recursion.
4. Obtain through child nodes:
(1) childNode.parentNode: Get the parent node of a known node.
The methods mentioned above are just some basic methods. If you use JavaScript libraries such as Prototype, you may also get other different methods, such as obtaining through the class of the node, etc. However, if you can flexibly use the above methods, I believe you should be able to handle most programs.

去掉重复并排序的方法:1、使用“Array.from(new Set(arr))”或者“[…new Set(arr)]”语句,去掉数组中的重复元素,返回去重后的新数组;2、利用sort()对去重数组进行排序,语法“去重数组.sort()”。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于Symbol类型、隐藏属性及全局注册表的相关问题,包括了Symbol类型的描述、Symbol不会隐式转字符串等问题,下面一起来看一下,希望对大家有帮助。

怎么制作文字轮播与图片轮播?大家第一想到的是不是利用js,其实利用纯CSS也能实现文字轮播与图片轮播,下面来看看实现方法,希望对大家有所帮助!

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于对象的构造函数和new操作符,构造函数是所有对象的成员方法中,最早被调用的那个,下面一起来看一下吧,希望对大家有帮助。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于面向对象的相关问题,包括了属性描述符、数据描述符、存取描述符等等内容,下面一起来看一下,希望对大家有帮助。

方法:1、利用“点击元素对象.unbind("click");”方法,该方法可以移除被选元素的事件处理程序;2、利用“点击元素对象.off("click");”方法,该方法可以移除通过on()方法添加的事件处理程序。

本篇文章给大家带来了关于JavaScript的相关知识,其中主要介绍了关于BOM操作的相关问题,包括了window对象的常见事件、JavaScript执行机制等等相关内容,下面一起来看一下,希望对大家有帮助。

foreach不是es6的方法。foreach是es3中一个遍历数组的方法,可以调用数组的每个元素,并将元素传给回调函数进行处理,语法“array.forEach(function(当前元素,索引,数组){...})”;该方法不处理空数组。


Hot AI Tools

Undresser.AI Undress
AI-powered app for creating realistic nude photos

AI Clothes Remover
Online AI tool for removing clothes from photos.

Undress AI Tool
Undress images for free

Clothoff.io
AI clothes remover

AI Hentai Generator
Generate AI Hentai for free.

Hot Article

Hot Tools

Dreamweaver Mac version
Visual web development tools

SublimeText3 Linux new version
SublimeText3 Linux latest version

SublimeText3 Chinese version
Chinese version, very easy to use

SublimeText3 English version
Recommended: Win version, supports code prompts!

ZendStudio 13.5.1 Mac
Powerful PHP integrated development environment
