JavaScript基础(24)_dom查询练习(一)

<!DOCTYPE html>
<html lang="zh">
<head>
    <meta charset="UTF-8">
    <link rel="stylesheet" href="../browser_default_style/reset.css">
    <title>dom查询练习一</title>
    <style>
        .text {
            width: 380px;
            height: 500px;
            margin: 20px 0px 0px 20px;
            border: 1px black solid;
        }

        p {
            margin: 10px 0px 5px 10px;
        }

        li {
            float: left;
            background-color: aquamarine;
            list-style-type: none;
            font-size: smaller;
            margin: 5px 3px 5px 10px;
            padding: 3px;
        }

        #name,
        #sex,
        button,
        input {
            margin-left: 10px;
        }

        button {
            margin-top: 5px;
        }
    </style>
    <script>
        window.onload = function () {
            // 为按钮1绑定事件,通过 "类名" 获取 "某一个对象" 时记得带上数组下标【0】
            var btn1 = document.getElementsByClassName("btn1")[0];
            btn1.onclick = function () {
                var kongque = document.getElementById("kongque");
                alert(kongque.innerHTML);
            }

            // 为按钮2绑定事件
            var btn2 = document.getElementsByClassName("btn2")[0];
            btn2.onclick = function () {
                // 获取一组类数组对象
                var text_list = document.getElementsByTagName("li");
                for (i = 0; i < text_list.length; i++) {
                    alert(text_list[i].innerHTML);
                }
            }

            // 为按钮3绑定事件
            var btn3 = document.getElementsByClassName("btn3")[0];
            btn3.onclick = function () {
                // 获取 “紧挨着类名为question1下一个兄弟元素ul的子元素li”
                var title1_list = document.querySelectorAll(".question1 + ul > li");
                for (i = 0; i < title1_list.length; i++) {
                    alert(title1_list[i].innerHTML);
                }
            }

            // 为按钮4绑定事件
            var btn4 = document.getElementsByClassName("btn4")[0];
            btn4.onclick = function () {
                var title1 = document.getElementsByClassName("question1")[0];
                //  注意:以下方式也行,不过下一个兄弟节点只是空白文本节点,所以是下下一个。
                // var title1_list = title1.nextSibling.nextSibling.children;

                // 获取 “紧挨着类名为question1下一个兄弟元素ul的子元素li”
                var title1_list = title1.nextElementSibling.children;
                for (i = 0; i < title1_list.length; i++) {
                    // 等价于:alert(title1_list[i].firstChild.nodeValue);
                    alert(title1_list[i].innerHTML);
                }
            }

            // 为按钮5绑定事件
            var btn5 = document.getElementsByClassName("btn5")[0];
            btn5.onclick = function () {
                var title5_list = document.getElementsByName("sex");
                for (i = 0; i < title5_list.length; i++) {
                    alert(title5_list[i].value);
                }
            }

            // 为按钮6绑定事件
            var btn6 = document.getElementsByClassName("btn6")[0];
            btn6.onclick = function () {
                var title4_text = document.getElementsByTagName("input")[0];
                alert(title4_text.value);
            }

            // 为按钮7绑定事件
            var btn7 = document.getElementsByClassName("btn7")[0];
            btn7.onclick = function () {
                var title4_text = document.getElementsByTagName("input")[0];
                title4_text.value = "张三";
                alert(title4_text.value);
            }

        }
    </script>
</head>

<body>
    <div class="text">
        <p class="question1">1、你喜欢哪个动物?</p>
        <ul>
            <li>小猫</li>
            <li>公鸡</li>
            <li id="kongque">孔雀</li>
            <li>兔子</li>
        </ul>
        <br><br>
        <p class="question2">2、你喜欢哪个城市?</p>
        <ul>
            <li>北京</li>
            <li>广州</li>
            <li>上海</li>
            <li>武汉</li>
        </ul>
        <br><br>
        <p class="question3">3、你喜欢哪项运动?</p>
        <ul>
            <li>羽毛球</li>
            <li>跳水</li>
            <li>体操</li>
            <li>篮球</li>
        </ul>
        <br><br>
        <form action="">
            <p>4、您的姓名是:</p>
            <input type="text" id="username" value="">
            <p>5、您的性别是:</p>
            <input type="radio" name="sex" value="man">男
            <input type="radio" name="sex" value="woman">女
        </form>
        <br>
        <button class="btn1">通过 "id属性" 为参数,查找题目1中第三个选项</button>
        <br>
        <button class="btn2">通过 "标签名" 为参数,查找文档中所有列表选项</button>
        <br>
        <button class="btn3">通过 "css选择器" 为参数,查找题1中所有列表选项</button>
        <br>
        <button class="btn4">通过 "元素节点"为对象,查找题1中所有列表选项</button>
        <br>
        <button class="btn5">通过 "name属性" 为参数,查找题5有关性别的选项</button>
        <button class="btn6">获取题4中的文本内容</button>
        <button class="btn7">设置题4中的文本内容为 "张三"</button>
    </div>
</body>
</html>

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

JS手写apply,call,bind函数

本篇文章咱们来手写简易版的apply&#xff0c;call&#xff0c;bind函数。 实现思路 首先咱们需要思考下这三个函数放到哪里比较合适&#xff0c;因为这三个函数是被函数对象调用的&#xff0c;并且每个函数都可以调用&#xff0c;所以不难想到有一个位置非常合适&#xff0c;…

解决Docker报错问题:Docker Desktop – Unexpected WSL error

最近因为准备在NAS上通过Docker容器方式安装MYSQL&#xff0c;发现https://hub.docker.com网站被墙了&#xff0c;无法自动安装&#xff0c;同时又找不到靠谱的离线镜像&#xff0c;所以准备在Window上安装Docker&#xff0c;通过电脑的网络代理制作离线镜像再上传到NAS上。 在…

媒体捕捉-iOS自定义二维码扫描功能

引言 随着iOS 7引入AV Foundation框架&#xff0c;二维码扫描功能已经成为iOS应用程序中不可或缺的一部分。现今&#xff0c;几乎每个应用都充分利用这一功能&#xff0c;为用户提供了诸如扫码登录、扫码填充等丰富多彩的便捷体验。这项技术不仅丰富了应用功能&#xff0c;也为…

校园-智慧门禁(卡码脸)解决方案

前言 入职新公司也已经一年有余&#xff0c;入职后主要从事的是门禁项目&#xff0c;公司设计的项目是偏saas化的智慧门禁系统&#xff0c;目前已经在多所大学上线&#xff0c;以下是对该项目的个人总结复盘。 一、系统主要功能和扩展功能 可实现学校统一门禁设备管理可实现人…

第14届蓝桥杯省赛scratch真题+解题思路+详细解析

一、选择题 一共有5道选择题&#xff0c;每题10分&#xff0c;共50分&#xff0c;严禁使用程序验证&#xff0c;选择题不答和答错不得分。 1. 运行以下程序&#xff0c;舞台上能看到几只小猫&#xff1f;&#xff08; &#xff09; A. 4 B. 5 C. 6 D. 7 答案&#xff…

软件测试|Linux三剑客之grep命令详解

简介 grep是一款在 Linux 和类 Unix 系统中广泛使用的文本搜索工具。它的名字来源于 Global Regular Expression Print&#xff08;全局正则表达式打印&#xff09;&#xff0c;它的主要功能是根据指定的模式&#xff08;正则表达式&#xff09;在文本文件中搜索并打印匹配的行…

reiserfs文件系统的磁盘布局

reiserfs文件系统的磁盘布局比较简单&#xff0c;它把整块分区分成相同大小的block块&#xff0c;一个block块的大小默认是4K&#xff0c;而最大块数未2^32次方&#xff0c;即一个分区最大大小为16TB。 reiserfs文件系统分区的前64KB总是为分区标签&#xff08;partition labe…

推荐收藏!万字长文带入快速使用 keras

这些年&#xff0c;有很多感悟&#xff1a;一个人精力是有限的&#xff0c;一个人视野也有有限的&#xff0c;你总会不经意间发现优秀人的就在身边。 看我文章的小伙伴应该经常听我说过的一句话&#xff1a;技术要学会交流、分享&#xff0c;不建议闭门造车。一个人可以走的很…

CSS基础笔记-03选择器

CSS基础笔记系列 《CSS基础笔记-01CSS概述》《CSS基础笔记-02动画》 前言 在前面两篇博客中&#xff0c;我实际上已经使用过了选择器。但到底什么是选择器、有什么作用&#xff0c;我反而不能表达出来。因此&#xff0c;决定记录了我的学习和思考。 什么是选择器 selector…

基于 HTTPS 协议配置 Git 连接 GitHub

文章目录 0.安装 Git1.注册 GitHub 账号2.配置 Git 的用户名和邮箱3.远程连接 GitHub 有两种传输协议4.基于 SSH 协议配置 Git 连接 GitHub5.基于 HTTPS 协议配置 Git 连接 GitHub5.1 创建 GitHub 个人访问令牌5.2 有两种方法将本地仓库和远程仓库关联起来5.2.1 第一种方法&…

【大数据】基于 Flink CDC 构建 MySQL 和 Postgres 的 Streaming ETL

基于 Flink CDC 构建 MySQL 和 Postgres 的 Streaming ETL 1.准备阶段1.1 准备教程所需要的组件1.2 下载 Flink 和所需要的依赖包1.3 准备数据1.3.1 在 MySQL 数据库中准备数据1.3.2 在 Postgres 数据库中准备数据 2.启动 Flink 集群和 Flink SQL CLI3.在 Flink SQL CLI 中使用…

x-cmd pkg | norwegianblue - 软件生命周期查询工具

目录 简介首次用户功能特点进一步探索 简介 norwegianblue 由 Hugo van Kemenade 使用 Python 开发&#xff0c;于 2021 年推出。用于显示多种产品的生命周期终止&#xff08;EOL&#xff09;日期的 CLI 工具。基于 endoflife.date 网站的接口&#xff0c;提供有关各种产品的最…

new和delete表达式的工作步骤

new表达式工作步骤 调用一个operator new库函数开辟未类型化的空间 void *operator new(size_t); 在为类型化的空间上调用构造函数&#xff0c;初始化对象的成员 返回相应类型的指针 delete表达式工作步骤 调用相应类型的析构函数,但析构函数并不能删除对象所在的空间&…

处cp社交类微信小程序前端开源(二)

在上一篇文章介绍如何用SpringBoot整合websocket实现在线聊天&#xff0c;这篇文章介绍如何将uniapp社交类前端源码打包部署微信小程序&#xff0c;和如何上线微信小程序&#xff0c;上线需要的资料&#xff0c;并且介绍我是如何获取用户&#xff0c;如何变现&#xff0c;现在的…

nginx下upstream模块详解

目录 一&#xff1a;介绍 二&#xff1a;特性介绍 一&#xff1a;介绍 Nginx的upstream模块用于定义后端服务器组&#xff0c;以及与这些服务器进行通信的方式。它是Nginx负载均衡功能的核心部分&#xff0c;允许将请求转发到多个后端服务器&#xff0c;并平衡负载。 在upst…

前端-基础 常用标签-超链接标签( 锚点链接 )

锚点链接 &#xff1a; 点击链接&#xff0c;可以快速定位到 页面中的某个位置 如果不好理解&#xff0c;讲一个例子&#xff0c;您就马上明白了 >>> 这个是 刘德华的百度百科 &#xff0c;可以看到&#xff0c;页面里面有很多内容&#xff0c;那就得有个目录了 …

RabbitMQ高级

文章目录 一.消息可靠性1.生产者消息确认2.消息持久化3.消费者确认4.消费者失败重试 MQ的一些常见问题 1.消息可靠性问题:如何确保发送的消息至少被消费一次 2.延迟消息问题:如何实现消息的延迟投递 3.高可用问题:如何避免单点的MQ故障而导致的不可用问题 4.消息堆积问题:如…

狂肝100小时,各大厂20W字面试真题分享

有很多童靴问我&#xff0c;有没有大厂的面试集合&#xff0c;可以针对性备考一下&#xff0c;我说面试题网络上有很多&#xff0c;随便搜索一下&#xff0c;就一大把吧。他们回复说&#xff0c;都是针对各个知识点的题目&#xff0c;想要吃透&#xff0c;至少要1-3个月的时间&…

NCC基础开发技能培训

YonBuilder for NCC 是一个带插件的eclipse工具&#xff0c;跟eclipse没什么区别 NC Cloud2021.11版本开发环境搭建改动 https://nccdev.yonyou.com/article/detail/495 不管是NC Cloud 新手还是老NC开发&#xff0c;在开发NC Cloud时开发环境搭建必看&#xff01;&#xff…

命令行模式的rancher如何安装?

在学习kubectl操作的时候&#xff0c;发现rancher也有命令行模式&#xff0c;学习整理记录此文。 说明 rancher 命令是 Rancher 平台提供的命令行工具&#xff0c;用于管理 Rancher 平台及其服务。 前提 已经参照前文安装过了rancher环境了&#xff0c;拥有了自己的k8s集群…