JS的DOM对象获取元素

news2024/11/25 18:39:56

测试1 getElementById

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            var odiv1 = document.getElementById("div1");
            //div1.style.color = "red"
            odiv1.style.color = "#00ffff"

            //注意这里是函数名get+Elements(复数,表示获取很多个)
            /*
            getElementsByTagName( )方法中的“elements”是一个复数,写的时候别漏掉“s”。这是因为getElementsByTagName( )获取的是多个元素(即集合),而getElementById( )获取的仅仅是一个元素。
            */
            var op = document.getElementsByTagName("p");
            if(!op){
                console.log("error 02")
                return;
            }
            //div1.style.color = "red"
            //op.style.color = "red"
            var colors = ["red","green","blue","yellow"]
            for(var i = 0; i < op.length; i++){
                // op[i].style.backgroundColor = colors[i]
                op[i].style.color = colors[i%colors.length]
            }
            //document.write(colors.length + "<br>")
            // document.write(5%colors.length + "<br>")
            // document.write(colors.length + "<br>")
            


            var oul = document.getElementById("list")
            var olis = oul.getElementsByTagName("li")
            console.log(olis.length)
            for(let i = 0;i < olis.length;i++){
                olis[i].innerHTML = "list:" + (i + 1)
                var j = i % colors.length
                console.log(j)
                olis[i].style.color = colors[i%colors.length]
            }
            
        }

    </script>
    <div id="div1">JavaScript</div>
    <p>第一个段落</p>
    <p>第二个段落</p>
    <p>第三个段落</p>
    <p>第四个段落</p>
    <p>第五个段落</p>
    <ul id="list">
        <li></li>
        <li></li>
        <li></li>
        <li></li>
        <li></li>
    </ul>
</body>
</html>

显示效果:

测试二:getElementsByTagName

在JavaScript中,如果想通过标签名来选中元素,我们可以使用getElementsByTagName( )方法来实现。getElementsByTagName,也就是“get elements by tag name”,意思是通过标签名来获取元素。同样地,getElementsByTagName( )类似于CSS中的“元素选择器”。

语法

document.getElementsByTagName("标签名")

说明

getElementsByTagName( )方法中的“elements”是一个复数,写的时候别漏掉“s”。这是因为getElementsByTagName( )获取的是多个元素(即集合),而getElementById( )获取的仅仅是一个元素。

这也是一个很有价值的测试代码,注意使用var定义变量和使用let定义变量的区别

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            document.body.innerHTML = "<div id='button_count'></div><input type='button' value='点我呀'/><br><input type='button' value='再点我呀'/><br><input type='button' value='右点我呀'/><br>"
            var oBtns = document.getElementsByTagName("input");

            for(let i = 0;i < oBtns.length;i++){
                oBtns[i].onclick = function(){
                    console.log(i)
                    console.log(oBtns[i].value);//i如果使用var定义会报错,使用let就不会
                    alert("点到我了:" + oBtns[i].value);
                }
            }
            var div1 = document.getElementById("button_count")
            div1.innerHTML = "页面中" + oBtns.length + "个按钮"
            
        }

    </script>
</body>
</html>

 效果:

点不同的按钮,会弹出不同内容的提示窗口

测试三 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            document.body.innerHTML ="<input id='btn' type='button' value='按钮'/><br>"
            var oBtn = document.getElementById('btn')
            oBtn.onclick = function(){
                alert(oBtn.value + " ")
            }
        }
    </script>

</body>
</html>

显示效果

 querySelectorAll选择器

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            var colors = ["red","green","blue","orange","yellow"]
            var oLis = document.querySelectorAll(".my_select")
            var odiv = document.getElementById("show")
            odiv.innerHTML = "获取的元素个数" + oLis.length
            if(oLis.length == 0){
                alert("no my_select element found")
                return
            }
            for(let i = 0; i < oLis.length; i++){
                oLis[i].style.color = colors[i%colors.length]
            }
        }
    </script>
    <div id="show"></div>
    <ul id = "list">
        <li>001</li>
        <li>002</li>
        <li class="my_select">003</li>
        <li class="my_select">004</li>
        <li class="my_select">005</li>
    </ul>

</body>
</html>

效果: 

 

 querySelector选择器

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            var colors = ["red","green","blue","orange","yellow"]
            var oLi = document.querySelector("#list li:nth-child(1)")
            oLi.style.color = colors[0]
            
        }
    </script>
    <div id="show"></div>
    <ul id = "list">
        <li>001</li>
        <li>002</li>
        <li class="my_select">003</li>
        <li class="my_select">004</li>
        <li class="my_select">005</li>
    </ul>

</body>
</html>

效果:

 getElementsByName

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            var oInput = document.getElementsByName("status")
            var Odiv = document.getElementById("show")
            Odiv.innerHTML = oInput.length
            oInput[0].checked = true            
            
        }
    </script>
    <div id="show"></div>
    <ul id = "list">
        <label><input type="radio" name="status" value="选项1"/>选项1</label>
        <label><input type="radio" name="status" value="选项2"/>选项2</label>
        <label><input type="radio" name="status" value="选项3"/>选项3</label>
    </ul>

</body>
</html>

效果:

复选框:

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
</head>
<body>
    <script>
        window.onload = function(){
            var oInput = document.getElementsByName("status")
            var Odiv = document.getElementById("show")
            Odiv.innerHTML = oInput.length
            for(var i=0; i < oInput.length; i++)
            oInput[i].checked = true            
            
        }
    </script>
    <div id="show"></div>
    <ul id = "list">
        <label><input type="checkbox" name="status" value="选项1"/>选项1</label>
        <label><input type="checkbox" name="status" value="选项2"/>选项2</label>
        <label><input type="checkbox" name="status" value="选项3"/>选项3</label>
    </ul>

</body>
</html>

 效果:

 document.title和document.body

由于一个页面只有一个title元素和一个body元素,因此对于这两个元素的选取,JavaScript专门提供了两个非常方便的方法:document.title和document.body。

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta http-equiv="X-UA-Compatible" content="IE=edge">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        p{
            color: #0000ff
        }
    </style>
</head>
<body>
    <script>
        window.onload = function(){
            document.title = "我就是标题"
            document.body.innerHTML = "<p style=\"font-size:60px\">我就是正文</p>"         
            
        }
    </script>
</body>
</html>

效果:

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/596206.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

I.MX RT1170:如何在SRAM/SDRAM运行程序

一般Flash为non-XIP时&#xff0c;我们需要在RAM上运行程序。还有一种情况&#xff0c;就是我们不想每次调试都要将程序写入Flash&#xff0c;然后由BootROM进行代码的拷贝和跳转&#xff0c;这样可以减少Flash的烧写次数。本篇文章就来讨论一下如何实现这两种情形的RAM代码运行…

chatgpt赋能python:如何更好地理解Python代码

如何更好地理解Python代码 引言 Python是一种高级编程语言&#xff0c;它越来越受欢迎。由于Python内置的强大功能和易学性&#xff0c;许多开发者选择使用Python来开发应用程序。但是&#xff0c;有时候我们可能会面临一些难以理解的代码&#xff0c;尤其是在阅读其他人的代…

一天吃透Spring面试八股文

内容摘自我的学习网站&#xff1a;topjavaer.cn Spring是一个轻量级的开源开发框架&#xff0c;主要用于管理 Java 应用程序中的组件和对象&#xff0c;并提供各种服务&#xff0c;如事务管理、安全控制、面向切面编程和远程访问等。它是一个综合性框架&#xff0c;可应用于所有…

解决Wsl2中Ubuntu无法更新软件的问题

本文排版不太好&#xff0c;详情可见笔记 有道云笔记 安装wsl2之后&#xff0c;在Ubuntu中更新软件&#xff0c;执行apt-get update命令报错&#xff0c;如下 rootjiangcheng01:~# sudo apt-get update Ign:1 http://mirrors.aliyun.com/ubuntu groovy InRelease Ign:2 http:…

一个注解的事儿,数据脱敏解决了

目录 什么是数据脱敏开整使用 Hutool 工具类实现数据掩码Hutool 信息脱敏工具类使用 Jackson 进行数据序列化脱敏 注解实现数据脱敏1、定义一个注解2、创建一个枚举类3、创建我们的自定义序列化类4、测试 项目 pom 文件 总结 本文主要分享什么是数据脱敏&#xff0c;如何优雅的…

chatgpt赋能python:Python从接口获取数据的重要性

Python从接口获取数据的重要性 在当今信息技术高速发展的时代&#xff0c;获取和分析数据是商业成功的关键因素之一。而在获取数据方面&#xff0c;使用Python编写接口来获取数据、自动化处理和分析数据的方法不仅更加高效&#xff0c;而且还可以把重点放在分析数据本身上&…

Element UI el-table form 表单的封装思路

Element UI el-table form 表单的封装思路 思路一: 将所有 form 表单类型都在 el-column-item 组件中定义好,然后根据传入的属性控制展示哪一个 form 表单类型 部分代码如下: <template><div><el-row style"padding: 0 20px"><el-col :span&…

2023年湖北七大员是哪七大员?七大员考试报名网站是哪里?启程别

2023年湖北七大员是哪七大员&#xff1f;七大员考试报名网站是哪里&#xff1f;启程别 住建厅七大员分类&#xff1a; 施工员&#xff08;土建&#xff0c;装饰装修&#xff0c;设备安装&#xff0c;市政工程&#xff09; 质量员&#xff08;土建&#xff0c;装饰装修&#x…

「从零入门推荐系统」20:推荐系统的未来发展

作者 | gongyouliu 编辑 | gongyouliu 随着科学技术的进步&#xff0c;信息技术、网络技术及物联网的快速发展&#xff0c;新信息的生产与传播更加便捷、快速。特别是最近大火的chatGPT、大模型技术引领的新一轮科技革命&#xff0c;让每一个人都可以轻松地生产各种各样的内容&…

ThreeJS教程:精灵模型Sprite作为标签

推荐&#xff1a;将 NSDT场景编辑器 加入你的3D工具链 3D工具集&#xff1a; NSDT简石数字孪生 精灵模型Sprite作为标签 实际开发的时候&#xff0c;可以使用精灵模型Sprite 颜色贴图作为标签&#xff0c;标注三维场景。 下面具体知识点&#xff0c;在精灵模型章节基本都讲解…

【多线程】阻塞队列

1. 认识阻塞队列和消息队列 阻塞队列也是一个队列&#xff0c;也是一个特殊的队列&#xff0c;也遵守先进先出的原则&#xff0c;但是带有特殊的功能。 如果阻塞队列为空&#xff0c;执行出队列操作&#xff0c;就会阻塞等待&#xff0c;阻塞到另一个线程往阻塞队列中添加元素(…

I.MX RT1170启动详解:Boot配置、Bootable image头的组成

文章目录 1 基础知识2 BOOT配置2.1 BOOT_CFG配置2.2 BOOT_MODE 3 Bootable image3.1 文件格式3.2 Bootable image头的组成3.3 Bootable image的生成3.4 例&#xff1a;BootROM之non-XIP加载过程3.5 例&#xff1a;bin文件分析 1 基础知识 &#xff08;1&#xff09;BootROM Bo…

遥感云大数据在灾害、水体与湿地领域典型案例及GPT模型教程

详情点击链接&#xff1a;遥感云大数据在灾害、水体与湿地领域典型案例及GPT模型教程 一&#xff1a;平台及基础开发平台 GEE平台及典型应用案例&#xff1b; GEE开发环境及常用数据资源&#xff1b; ChatGPT、文心一言等GPT模型 JavaScript基础&#xff1b; GEE遥感云重…

什么是homography变换

就是33的可逆矩阵对齐次坐标的变换。也叫射影变换&#xff0c;直射变换。 projectivity projective transformation collineation homography 这几个词在描述齐次坐标下的变换时是同义的。

让IPad变成你的生产力工具?在IPad上用Vscode写代码搞开发

文章目录 前言视频教程1. 本地环境配置2. 内网穿透2.1 安装cpolar内网穿透(支持一键自动安装脚本)2.2 创建HTTP隧道 3. 测试远程访问4. 配置固定二级子域名4.1 保留二级子域名4.2 配置二级子域名 5. 测试使用固定二级子域名远程访问6. iPad通过软件远程vscode6.1 创建TCP隧道 7…

POSTGRESQL 索引添加不合理有什么负面影响

开头还是介绍一下群&#xff0c;如果感兴趣polardb ,mongodb ,mysql ,postgresql ,redis 等有问题&#xff0c;有需求都可以加群群内有各大数据库行业大咖&#xff0c;CTO&#xff0c;可以解决你的问题。加群请联系 liuaustin3 &#xff0c;在新加的朋友会分到2群&#xff08;共…

软考A计划-试题模拟含答案解析-卷十六

点击跳转专栏>Unity3D特效百例点击跳转专栏>案例项目实战源码点击跳转专栏>游戏脚本-辅助自动化点击跳转专栏>Android控件全解手册点击跳转专栏>Scratch编程案例 &#x1f449;关于作者 专注于Android/Unity和各种游戏开发技巧&#xff0c;以及各种资源分享&am…

基于SpringBoot和vue的若依后台管理系统 部署

RuoYi-Vue是一款前后端分离的极速后台开发框架&#xff0c;基于SpringBoot和Vue。 目录 一、准备 二、启动前端项目 解决报错&#xff1a;digital envelope routines::unsupported 【测试】 三、启动后端项目 四、运行数据库sql文件建表 五、开启redis缓存服务 【redis…

基于html+css的图展示103

准备项目 项目开发工具 Visual Studio Code 1.44.2 版本: 1.44.2 提交: ff915844119ce9485abfe8aa9076ec76b5300ddd 日期: 2020-04-16T16:36:23.138Z Electron: 7.1.11 Chrome: 78.0.3904.130 Node.js: 12.8.1 V8: 7.8.279.23-electron.0 OS: Windows_NT x64 10.0.19044 项目…

java 利用poi根据excel模板导出数据(一)

前言 作为B端开发&#xff0c;导出数据是不可以避免的&#xff0c;但是有时候需求很变态&#xff0c;表头复杂的一笔&#xff0c;各种合并单元格&#xff0c;如下图&#xff1a; 这些虽说用代码可以实现&#xff0c;但是很繁琐&#xff0c;而且代码并不能通用&#xff0c;遇到…