网站首页 > 技术文章 正文
开篇一张美女,大家国庆节快乐,感谢大家百忙之中来看我这张美女图。给大家上黑丝。
言归正传,今天介绍下获取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[]。
好了今天的内容就分享到这,剩下的内容我们下次继续,多多练习掌握技巧和之间的区别。加油!
下次还有美女
- 上一篇: 一文解读JavaScript中的文档对象(DOM)
- 下一篇: 网页js代码,狡猾的标题栏
猜你喜欢
- 2024-11-20 2024年 React.js快速入门备忘清单,让你轻松掌握 React.js
- 2024-11-20 个人博客美化2之二次元组件及背景特效
- 2024-11-20 如何使用 ChatGPT 进行抓取
- 2024-11-20 在移动端轻松查看网页源代码:View Source 2.0
- 2024-11-20 html开发笔记03- 标题标签
- 2024-11-20 网页js代码,狡猾的标题栏
- 2024-11-20 一文解读JavaScript中的文档对象(DOM)
- 2024-11-20 自信少年最出彩,广西广播电视台知名主播为你们打call
- 2024-11-20 你真的熟悉 HTML 标签吗?
- 2024-11-20 JavaScript-document对象 239
- 标签列表
-
- content-disposition (47)
- nth-child (56)
- math.pow (44)
- 原型和原型链 (63)
- canvas mdn (36)
- css @media (49)
- promise mdn (39)
- readasdataurl (52)
- if-modified-since (49)
- css ::after (50)
- border-image-slice (40)
- flex mdn (37)
- .join (41)
- function.apply (60)
- input type number (64)
- weakmap (62)
- js arguments (45)
- js delete方法 (61)
- blob type (44)
- math.max.apply (51)
- js (44)
- firefox 3 (47)
- cssbox-sizing (52)
- js删除 (49)
- js for continue (56)
- 最新留言
-