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 获取的都是伪数组集合,都不能直接注册事件,需要在后面加上索引

相关推荐
chenbin___几秒前
react native中 createAsyncThunk 的详细说明,及用法示例(转自通义千问)
javascript·react native·react.js
摆烂工程师1 分钟前
(2025年11月)开发了 ChatGPT 导出聊天记录的插件,ChatGPT Free、Plus、Business、Team 等用户都可用
前端·后端·程序员
gongzemin11 分钟前
使用阿里云ECS部署前端应用
前端·vue.js·后端
用户411800341534112 分钟前
Flutter课题汇报
前端
3秒一个大13 分钟前
HTML5 敲击乐应用:从代码到交互的完整实现
html
环信15 分钟前
实战教程|快速上线音视频通话:手把手教你实现呼叫与接听全流程
前端
Dgua16 分钟前
✨TypeScript快速入门第一篇:从基础到 any、unknown、never 的实战解析
前端
海云前端116 分钟前
Vue3 大屏项目投屏功能开发:多显示器适配实践
前端
技术小丁32 分钟前
使用 HTML + JavaScript 实现酒店订房日期选择器(附完整源码)
前端·javascript
hashiqimiya33 分钟前
harmonyos的鸿蒙的跳转页面的部署
开发语言·前端·javascript