鱼C论坛

 找回密码
 立即注册
查看: 2066|回复: 5

[庖丁解牛] 0 1 4 1 ★ 获取元素之getElementsByTagName |【获取】

[复制链接]
发表于 2017-6-14 21:58:17 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 不二如是 于 2017-6-14 22:42 编辑


                               
登录/注册后可看大图


0 1 1 9 ★★ BOM与DOM (88-118)| 【总结】入门级别,介绍了getElementsByTagName方法。

现在深入死磕下这个方法。





getElementsByTagName方法返回一个对象数组,每个对象分别对应着文档里有着给定标签的一个元素

该方法只有一个参数标签名。语法:
  1. document.getElementByTagName("标签名");
复制代码


在0 1 4 0 介绍的getElementById也是返回一个值,只不过是对象

而getElementsByTabgName方法返回的是一个对象数组

千万别搞混了~(我猜说完,就更容易搞混了)





上一个简单的例子:
  1. document.getElementsByTagName("li");
复制代码


这个调用将返回一个对象数组,每个对象分别对应着document对象中的一个列表项元素。

与任何其他的数组一样,我们可以利用length属性查出这个数组里的元素个数

现在继续在下面这段代码中进行实验:
  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4.     <meta charset="UTF-8">
  5.     <title>鱼C工作室</title>
  6. </head>
  7. <body>
  8. <h1>鱼C-Web开发</h1>
  9. <p title="slogan">Change the World By Program</p>
  10. <ul id="class">
  11.     <li>HTML5-庖丁解牛</li>
  12.     <li class="star">JavaScript-庖丁解牛</li>
  13.     <li>PHP&MySQl-庖丁解牛</li>
  14. </ul>
  15. </body>
  16. </html>
复制代码


★第一步,利用getElementByTagName查找:
  1. document.getElementsByTagName("li");
复制代码


★第二步,利用循环语句,输出上面查找到的内容
  1. for(var i = 0 ; i <document.getElementsByTagName("li").length ; i++ )
  2. {
  3. alert("typeof document.getElementsByTagName("li")[i]");
  4. }
复制代码


★启动程序,看结果,显示3个object
6月-14-2017 07-21-47.gif





从代码可读性来讲,上面的写法是极其恶心滴·


只需要引入一个变量,即可让代码变的干净漂亮(上述原因,也是变量被发明的原因之一):
  1. var items = document.getElementsByTagName("li");
  2.    
  3.     for(var i = 0 ; i < items.length ; i++)
  4.     {
  5.         alert(typeof items[i]);
  6.     }
复制代码





getElementsByTabgName,允许使用通配符(*),然后就能知道整个文档中的元素个数

修改代码:
  1. var a = document.getElementsByTagName("*").length;
  2.     console.log(typeof a);
  3.     console.dir(a);
复制代码

Snip20170614_166.png


我想要看看id为class的<ul>,包含了哪些元素怎么办?


在之前咱们讲过getElementById可以用来找到id,再结合上面的通配符,理论上就可以完成任务哈~

上代码:
  1. //先找到id,并存储到findId变量中
  2.     var findId = document.getElementById("class");

  3.     //基于findId,进一步查找其内所有元素
  4.     var findLi = findId.getElementsByTagName("*");

  5.     //循环输出
  6.     for(var i = 0 ; i < findLi.length ; i++)
  7.     {
  8.         console.log(findLi[i]);
  9.     }
复制代码

Snip20170614_167.png


这位鱼油,如果喜欢本系列Js帖子,请订阅 专辑&#9758;传送门)(不喜欢更要订阅

评分

参与人数 1荣誉 +5 鱼币 +5 贡献 +3 收起 理由
睦ちゃん她爹 + 5 + 5 + 3

查看全部评分

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-6-15 06:56:41 | 显示全部楼层
H5新语法一般是用
  1. document.querySelectorAll(selectors);
复制代码
这个了,用的css3选择器非常方便
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-8-31 11:09:41 | 显示全部楼层
突然就感觉jq的$是多么伟大
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2018-9-15 09:34:51 | 显示全部楼层
报告老师 你确定
alert("typeof document.getElementsByTagName("li")[i]");
输出的不是字符串 ?
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-9-11 19:09:10 | 显示全部楼层
“getElementsByTabgName,允许使用通配符(*),然后就能知道整个文档中的元素个数”,捉个虫,多了一个b
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2023-9-12 10:46:06 | 显示全部楼层
好像那个alert一直都没弹出来,就是正常显示的字符串
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2024-4-25 16:06

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表