getElementById,getElementsByName,getElementsByTagName,getElementsByClassName四者之间的区别

本文主要是介绍getElementById,getElementsByName,getElementsByTagName,getElementsByClassName四者之间的区别,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在《Javascript DOM 编程艺术》与 W3school 中是这样定义的:

getElementById():这个方法将返回一个与那个有着给定id属性值的元素节点对应的对象。

下面这个案例我是想通过触发test()函数后,给一个id为“div1”的div层添加背景色为黄颜色。

<!DOCTYPE html>
<html>
<head><title>shopping list</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><link href="css/css.css" rel="stylesheet" type="text/css">
</head><h1>what to buy</h1><P title="a gentle reminder">Don't forget to buy this stuff.</P><ul id="purchases"><li>A tin of beans</li><li class="sale">Cheese</li><li class="sale important">milk</li></ul><div id="div1">helloworld</div><input type="button" value="按钮" onclick="test()"/><script>function test(){document.getElementById("div1").style.backgroundColor="yellow";}</script>
</body>
</html>

输出结果:

这里写图片描述

getElementsByName():方法可返回带有指定名称的对象的集合。

这个案例是为获取无序列表中名字name叫“t”的li 的长度。

<!DOCTYPE html>
<html>
<head><title>shopping list</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><link href="css/css.css" rel="stylesheet" type="text/css">
</head><h1>what to buy</h1><P title="a gentle reminder">Don't forget to buy this stuff.</P><ul id="purchases"><li name="t">A tin of beans</li><li name="t" class="sale">Cheese</li><li name="t" class="sale important">milk</li></ul><div id="div1">helloworld</div><input type="button" value="按钮" onclick="test()"/><script>function test(){alert(document.getElementsByName("t").length);}</script>
</body>
</html>

输出结果:

这里写图片描述

getElementsByTagName():方法返回一个对象数组,每个对象分别对应着文档里有着给定标签的一个元素。这个理解起来有点拗口。
W3school中是这样定义的:此方法可返回带有指定标签名的对象的集合。

下面这个我是要获得script标签的长度

<!DOCTYPE html>
<html>
<head><title>shopping list</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><link href="css/css.css" rel="stylesheet" type="text/css">
</head><h1>what to buy</h1><P title="a gentle reminder">Don't forget to buy this stuff.</P><ul id="purchases"><li name="t" class="sale">A tin of beans</li><li name="t" class="sale">Cheese</li><li name="t" class="sale important">milk</li></ul><div id="div1">helloworld</div><input type="button" value="按钮" onclick="test()"/><script>function test(){alert(document.getElementsByTagName("script").length);}</script>
</body>
</html>

输出结果:

这里写图片描述

getElementsByClassName():方法返回文档中所有指定类名的元素集合,作为 NodeList 对象。

下面这个是要设置class=”sale”且数组下标为:1的li的背景色为:red

<!DOCTYPE html>
<html>
<head><title>shopping list</title><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><link href="css/css.css" rel="stylesheet" type="text/css">
</head><h1>what to buy</h1><P title="a gentle reminder">Don't forget to buy this stuff.</P><ul id="purchases"><li name="t" class="sale">A tin of beans</li><li name="t" class="sale">Cheese</li><li name="t" class="sale important">milk</li></ul><div id="div1">helloworld</div><input type="button" value="按钮" onclick="test()"/><script>function test(){var x=document.getElementsByClassName("sale");x[1].style.backgroundColor="red";}</script>
</body>
</html>

输出结果:

这里写图片描述

这篇关于getElementById,getElementsByName,getElementsByTagName,getElementsByClassName四者之间的区别的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/824368

相关文章

C# 比较两个list 之间元素差异的常用方法

《C#比较两个list之间元素差异的常用方法》:本文主要介绍C#比较两个list之间元素差异,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友参考下吧... 目录1. 使用Except方法2. 使用Except的逆操作3. 使用LINQ的Join,GroupJoin

深度解析Java项目中包和包之间的联系

《深度解析Java项目中包和包之间的联系》文章浏览阅读850次,点赞13次,收藏8次。本文详细介绍了Java分层架构中的几个关键包:DTO、Controller、Service和Mapper。_jav... 目录前言一、各大包1.DTO1.1、DTO的核心用途1.2. DTO与实体类(Entity)的区别1

深度解析Spring Boot拦截器Interceptor与过滤器Filter的区别与实战指南

《深度解析SpringBoot拦截器Interceptor与过滤器Filter的区别与实战指南》本文深度解析SpringBoot中拦截器与过滤器的区别,涵盖执行顺序、依赖关系、异常处理等核心差异,并... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现

Before和BeforeClass的区别及说明

《Before和BeforeClass的区别及说明》:本文主要介绍Before和BeforeClass的区别及说明,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Before和BeforeClass的区别一个简单的例子当运行这个测试类时总结Before和Befor

java Long 与long之间的转换流程

《javaLong与long之间的转换流程》Long类提供了一些方法,用于在long和其他数据类型(如String)之间进行转换,本文将详细介绍如何在Java中实现Long和long之间的转换,感... 目录概述流程步骤1:将long转换为Long对象步骤2:将Longhttp://www.cppcns.c

Android学习总结之Java和kotlin区别超详细分析

《Android学习总结之Java和kotlin区别超详细分析》Java和Kotlin都是用于Android开发的编程语言,它们各自具有独特的特点和优势,:本文主要介绍Android学习总结之Ja... 目录一、空安全机制真题 1:Kotlin 如何解决 Java 的 NullPointerExceptio

Linux中的more 和 less区别对比分析

《Linux中的more和less区别对比分析》在Linux/Unix系统中,more和less都是用于分页查看文本文件的命令,但less是more的增强版,功能更强大,:本文主要介绍Linu... 目录1. 基础功能对比2. 常用操作对比less 的操作3. 实际使用示例4. 为什么推荐 less?5.

Java 关键字transient与注解@Transient的区别用途解析

《Java关键字transient与注解@Transient的区别用途解析》在Java中,transient是一个关键字,用于声明一个字段不会被序列化,这篇文章给大家介绍了Java关键字transi... 在Java中,transient 是一个关键字,用于声明一个字段不会被序列化。当一个对象被序列化时,被

解读@ConfigurationProperties和@value的区别

《解读@ConfigurationProperties和@value的区别》:本文主要介绍@ConfigurationProperties和@value的区别及说明,具有很好的参考价值,希望对大家... 目录1. 功能对比2. 使用场景对比@ConfigurationProperties@Value3. 核

Spring Boot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)

《SpringBoot拦截器Interceptor与过滤器Filter深度解析(区别、实现与实战指南)》:本文主要介绍SpringBoot拦截器Interceptor与过滤器Filter深度解析... 目录Spring Boot拦截器(Interceptor)与过滤器(Filter)深度解析:区别、实现与实