JS获取div里面的其它元素的两种方法

通过JS的DOM获取div里面的其它元素的两种方法 getElementsByTagName 和 querySelector ,具体使用方法如下:

html 复制代码
<div id="box">
        <input type="text" id="h1" value="h1">
        <input type="text" id="h2" value="h2">
</div>

getElementsByTagName的获取方式:

javascript 复制代码
<script>
        var box = document.getElementById('box')
        var input = box.getElementsByTagName('input')[0];
        input.style.backgroundColor = 'pink'
</script>

这里的 ('input')[0] 因为getElementsByTagName获取的是一个伪数组集合,不能直接注册事件,必须要提取单个元素才可以,[0] 是索引号。效果图如下:

如果可以改为 [1] 就是 h2 改变背景,如果需要获取所有的input,可以用循环

javascript 复制代码
var box = document.getElementById('box')
var input = box.getElementsByTagName('input');
for (var i = 0; i < input.length; i++) {
      input[i].style.backgroundColor = 'pink'
}

querySelector的获取方式:

javascript 复制代码
var input = document.querySelector('#box input')
input.style.backgroundColor = 'pink';

这种方法是实际开发中常用的方法,比较严谨一些,不过 querySelector 只能获取第一个,如果想要获取全部可以使用:

javascript 复制代码
var input = document.querySelectorAll('input')
for (var i = 0; i < input.length; i++) {
     input[i].style.backgroundColor = 'pink'
}

注意:getElementsByTagName、getElementsByClassName、getElementsByName、querySelectorAll 获取的都是伪数组集合,都不能直接注册事件,需要在后面加上索引

相关推荐
FSHOW2 小时前
【独立开发日记】MQ端到端类型安全
前端·javascript·后端
老华带你飞2 小时前
社区互助|基于SSM+vue的社区互助平台的设计与实现(源码+数据库+文档)
java·前端·数据库·vue.js·小程序·毕设·社区互助平台
一支鱼2 小时前
前端使用次数最多的工具封装
前端·typescript·编程语言
GIS之路2 小时前
GDAL 简介
前端
前端工作日常3 小时前
单元测试与E2E测试中使用浏览器的原因及区别
前端·单元测试
chxii3 小时前
7.2elementplus的表单布局与模式
javascript·vue.js·elementui
Js_cold3 小时前
Notepad++使用技巧1
前端·javascript·fpga开发·notepad++
接着奏乐接着舞。4 小时前
前端RSA加密遇到Java后端解密失败的问题解决
java·开发语言·前端
dreams_dream4 小时前
vue中的与,或,非
前端·javascript·vue.js
柳杉4 小时前
使用three.js搭建3d隧道监测-3
前端·javascript·three.js