网站首页 > 技术文章 正文
开篇一张美女,大家国庆节快乐,感谢大家百忙之中来看我这张美女图。给大家上黑丝。
言归正传,今天介绍下获取DOM元素的一些方法。根据w3school上介绍的大概有
- document.getElementById();
- document.getElementsByName();
- document.getElementsByClassName();
- document.getElementsByTagName();
- CSS选择器
- document.querySelector();
- document.querySelectorAll();
- 对象选择器
- document.forms();
- 还有以下 HTML 对象(和对象集合)也可以获取
- document.anchors
- document.body
- document.documentElement
- document.embeds
- document.forms
- document.head
- document.images
- document.links
- document.scripts
- document.title
那咱们就老规矩按F12进开发者模式,今天我们先了解下下面这四个
document.getElementById('js_media_list'); //下图红色框
document.getElementsByName('file'); //下图绿色框
document.getElementsByClassName('mp-head'); //下图蓝色框
document.getElementsByTagName('body'); //下图黑色框
可以看到除了document.getElementById();返回的是元素节点,其余几个方法返回的是Nodelist和HTMLCollection,这两个是类似数组的一个集合,都有数组的length属性,还可以通过索引访问内部元素。
document.getElementById();
通过id查找元素。如果元素被找到,此方法会以对象返回该元素, 如果未找到元素,返回null。我们试一下
可以看到,我们查id='js_media_list'的元素,返回了元素节点<ul>;当我们查id='ssssss'的元素,由于文档中没有这个id的元素,所以返回了null
document.getElementsByName();
根据name属性查找所有匹配值, 若存在返回NodeList数组对象,若不存在返回空的Nodelist[]。我们看看一下
可以看到,我们查name='file'的元素,返回了Nodelist里面有一个元素节点<input>;当我们查name='ssssss'的元素,由于文档中没有这个name属性的元素,所以返回了空的Nodelist[]。
document.getElementsByClassName('');
如果元素只有一个class属性,会查找页面上所有的class属性值匹配的元素。如果有多个多个class属性,可以选其中一个进行匹配,也可以多个同时匹配,如果存在则返回HTMLCollection对象(类似数组,有数组的length属性和数组索引来访问内部元素),如果不存在则返回空的HTMLCollection[]。
可以看到,我们查class='tpl_item tpl_item_dropdown jsInsertIcon img'的元素(当包含多个class属性是,必须同时满足这几个属性值),返回了HTMLCollection里面有一个元素节点<li>;当我们查class='tpl_item_dropdown'的元素,返回了HTMLCollection里面有三个元素节点<li>;当我们查class='ssssss'的元素,由于文档中没有这个class属性值的元素,所以返回了空的HTMLCollection[]。
document.getElementsByTagName();
通过tag标签属性查找所有匹配的标签元素, 返回HTMLCollection 数组对象;若不存在则返回空的HTMLCollection[]。我们试试看
可以看到,我们查TagName='li'的元素,返回了HTMLCollection里面有17个元素节点<input>;当我们查TagName='ssssss'的元素,由于文档中没有对应的元素标签,所以返回了空的HTMLCollection[]。
好了今天的内容就分享到这,剩下的内容我们下次继续,多多练习掌握技巧和之间的区别。加油!
下次还有美女
猜你喜欢
- 2025-01-02 JavaScript字符串toString()方法教程
- 2025-01-02 vue3 - 内置组件Teleport的使用
- 2025-01-02 网页三维CAD中加载和保存STEP模型
- 2025-01-02 在.NET Web API中设置响应输出Json数据格式的两种常用方式
- 2025-01-02 剖析Selenium代码执行时元素查找失败的缘由
- 2025-01-02 H5的Canvas绘图——使用fabricjs绘制一个可多选的随机9宫格
- 2025-01-02 jscanify:支持 Node.js/浏览器/React 移动文档扫描仪
- 2025-01-02 js事件机制详解
- 2025-01-02 Java ArrayList用法详解附代码示例
- 2025-01-02 如何用枚举快速提高编程效率,数据元素快速对应,小枚举大作用
- 02-21走进git时代, 你该怎么玩?_gits
- 02-21GitHub是什么?它可不仅仅是云中的Git版本控制器
- 02-21Git常用操作总结_git基本用法
- 02-21为什么互联网巨头使用Git而放弃SVN?(含核心命令与原理)
- 02-21Git 高级用法,喜欢就拿去用_git基本用法
- 02-21Git常用命令和Git团队使用规范指南
- 02-21总结几个常用的Git命令的使用方法
- 02-21Git工作原理和常用指令_git原理详解
- 最近发表
- 标签列表
-
- cmd/c (57)
- c++中::是什么意思 (57)
- sqlset (59)
- ps可以打开pdf格式吗 (58)
- phprequire_once (61)
- localstorage.removeitem (74)
- routermode (59)
- vector线程安全吗 (70)
- & (66)
- java (73)
- org.redisson (64)
- log.warn (60)
- cannotinstantiatethetype (62)
- js数组插入 (83)
- resttemplateokhttp (59)
- gormwherein (64)
- linux删除一个文件夹 (65)
- mac安装java (72)
- reader.onload (61)
- outofmemoryerror是什么意思 (64)
- flask文件上传 (63)
- eacces (67)
- 查看mysql是否启动 (70)
- java是值传递还是引用传递 (58)
- 无效的列索引 (74)