当前位置: 首页 > news >正文

【JS】Chapter6-Dom 获取属性操作

站在巨人的肩膀上

黑马程序员前端JavaScript入门到精通全套视频教程,javascript核心进阶ES6语法、API、js高级等基础知识和实战教程

(六)Dom 获取&属性操作

以下的变量可以将 let 改为 const:

let arr = ['red', 'green']
arr.push('pink')
console.log(arr)    // ['red', 'green', 'pink']let person = {uname: 'pink老师',age: 18,gender: '女'
}
person.address = '武汉黑马'
console.log(person)
  • const 声明的值不能更改,而且 const 声明变量的时候需要里面进行初始化
  • 但是对于引用数据类型,const 声明的变量,里面存的不是值,是地址!
// 以下写法错误,因为他们地址不一样:
const names = []
names = [1,2,3]const obj = {}
obj = {uname: 'pink老师'
}// 应该如下写法:
const names = []
names[0] = 1
names[1] = 2
names[2] = 3const obj = {}
obj.uname = 'pink老师'
  • 为什么const声明的对象可以修改里面的属性?
    • 因为对象是引用类型,里面存储的是地址,只要地址不变,就不会报错
    • 建议数组和对象使用 const 来声明
  • 声明变量先给const,如果发现它后面是要被修改的,再改为let
  • 如果基本数据类型的值或者引用类型的地址发生变化的时候,需要用let

1. Web API 基本认知

1.1 作用和分类

  • 作用: 就是使用 JS 去操作 html 和浏览器
  • 分类:DOM (文档对象模型)、BOM(浏览器对象模型)

1.2 什么是DOM

  • DOM(Document Object Model——文档对象模型)是用来呈现以及与任意 HTML 或 XML文档交互的API
  • 白话文:DOM是浏览器提供的一套专门用来 操作网页内容 的功能
  • DOM作用
    • 开发网页内容特效和实现用户交互

1.3 DOM树

  • DOM树是什么
    • 将 HTML 文档以树状结构直观的表现出来,我们称之为文档树或 DOM 树
    • 描述网页内容关系的名词
    • 作用:文档树直观的体现了标签与标签之间的关系

1.4 DOM对象(重要)

  • DOM对象:浏览器根据html标签生成的 JS对象
    • 所有的标签属性都可以在这个对象上面找到
    • 修改这个对象的属性会自动映射到标签身上
  • DOM的核心思想
    • 把网页内容当做对象来处理
  • document 对象
    • 是 DOM 里提供的一个对象
    • 所以它提供的属性和方法都是用来访问和操作网页内容的
      • 例:document.write()
    • 网页所有内容都在document里面

2. 获取DOM对象

查找元素DOM元素就是利用 JS 选择页面中标签元素。

2.1 根据CSS选择器来获取DOM元素 (重点)

  1. 选择匹配的第一个元素
  • 语法:
    document.querySelector('css选择器')
    
  • 参数:
    • 包含一个或多个有效的CSS选择器 字符串
  • 返回值:
    • CSS选择器匹配的第一个元素,一个 HTMLElement对象。
    • 如果没有匹配到,则返回null。
  • 多参看文档:https://developer.mozilla.org/zh-CN/docs/Web/API/Document/querySelector
  1. 选择匹配的多个元素
  • 语法:
    document.querySelectorAll('css选择器')
    
  • 参数:
    • 包含一个或多个有效的CSS选择器 字符串
  • 返回值:
    • CSS选择器匹配的NodeList 对象集合
  • 例如:
    document.querySelectorAll('ul li')
    
  1. document.querySelectorAll('css选择器') 得到的是一个伪数组:
    • 有长度有索引号的数组
    • 但是没有 pop() push() 等数组方法
  • 想要得到里面的每一个对象,则需要遍历(for)的方式获得。
  • 哪怕只有一个元素,通过querySelectAll() 获取过来的也是一个伪数组,里面只有一个元素而已
  • querySelector() 只能选择一个元素,可以直接操作。
  • querySelectorAll() 可以选择多个元素,得到的是伪数组,需要遍历得到每一个元素。
  • 小括号里面的参数的注意事项:
    • 里面写css选择器;
    • 必须是字符串,也就是必须加引号。

2.2 其他获取DOM元素方法(了解)

// 根据 id 获取一个元素
document.getElementById('nav')
// 根据标签获取一类元素。获取页面所有div
document.getElementsByTagName('div')
// 根据类名获取元素。获取页面所有类名为w的
document.getElementsByClassName('w')

3. 操作元素内容

  • DOM对象都是根据标签生成的,所以操作标签,本质上就是操作DOM对象。
  • 就是操作对象使用的点语法。
  • 如果想要修改标签元素的里面的内容,则可以使用如下几种方式:
    • 对象.innerText 属性
    • 对象.innerHTML 属性

3.1 元素 innerText 属性

  • 将文本内容添加/更新到任意标签位置
  • 显示纯文本,不解析标签
  • 例子:
    const info = document.querySelector('.info')
    // 获取标签内部的文字
    // console.log(info.innerText)
    // 添加/修改标签内部文字内容
    info.innerText = '哈哈,你好...'
    

3.2 元素 innerHTML 属性

  • 将文本内容添加/更新到任意标签位置
  • 会解析标签,多标签建议使用模板字符
  • 例子:
    const info = document.querySelector('.info')
    // 获取标签内部的文字
    // console.log(info.innerHTML)
    // 添加/修改标签内部文字内容
    info.innerHTML = '哈哈,<strong>你好</strong>...'
    

4. 操作元素属性

4.1 操作元素常用属性

  • 还可以通过 JS 设置/修改标签元素属性,比如通过 src更换 图片
  • 最常见的属性比如: href、title、src 等
  • 语法:
    对象.属性 = 值
    
  • 例子:
    // 1. 获取元素
    const pic = document.querySelector('img')
    // 2. 操作元素
    pic.src = './images/b02.jpg'
    pic.title = '你好'
    

4.2 操作元素样式属性

  • 还可以通过 JS 设置/修改标签元素的样式属性。
    • 比如通过轮播图小圆点自动更换颜色样式
    • 点击按钮可以滚动图片,这是移动的图片的位置 left 等等
  • 学习路径:
    • 通过 style 属性操作CSS
    • 操作类名(className) 操作CSS
    • 通过 classList 操作类控制CSS
  1. 通过 style 属性操作CSS
  • 语法:
    对象.style.样式属性 = 值
    
  • 例子:
    const box = document.querySelector('.box')
    // 修改元素样式
    box.style.width = '200px'
    box.style.marginTop = '15px'
    box.style.backgroundColor = 'pink'
    
  • 注意:
    • 修改样式通过style属性引出
    • 如果属性有-连接符,需要转换为小驼峰命名法
    • 赋值的时候,需要的时候不要忘记加css单位
  • 标签选择body时,因为body是唯一的标签,可以直接写 document.body.style。
  1. 操作类名(className) 操作CSS
  • 如果修改的样式比较多,直接通过style属性修改比较繁琐,我们可以通过借助于css类名的形式。
  • 语法:
    // active 是一个 css 类名
    元素.className = 'active'
    
  • 注意:
    • 由于class是关键字, 所以使用className去代替
    • className是使用新值换旧值,如果需要添加一个类,需要保留之前的类名
  1. 通过 classList 操作类控制CSS
  • 为了解决className 容易覆盖以前的类名,我们可以通过classList方式追加和删除类名
  • 语法:
    // 追加一个类
    元素.classList.add('类名')
    // 删除一个类
    元素.classList.remove('类名')
    // 切换一个类
    元素.classList.toggle('类名')
    

4.3 操作表单元素属性

  • 表单很多情况,也需要修改属性,比如点击眼睛,可以看到密码,本质是把表单类型转换为文本框
  • 正常的有属性有取值的 跟其他的标签属性没有任何区别
  • 获取: DOM对象.属性名
  • 设置: DOM对象.属性名 = 新值
表单.value = '用户名'
表单.type = 'password'
  • 表单属性中添加就有效果,移除就没有效果,一律使用布尔值表示 如果为true 代表添加了该属性 如果是false 代表移除了该属性。比如: disabled、checked、selected

4.4 自定义属性

  • 标准属性: 标签天生自带的属性 比如class id title等, 可以直接使用点语法操作比如:disabled、checked、selected
  • 自定义属性:
    • 在html5中推出来了专门的data-自定义属性
    • 在标签上一律以data-开头
    • 在DOM对象上一律以dataset对象方式获取
  • 例子:
    <body><div class="box" data-id="10">盒子</div><script>const box = document.querySelector('.box')console.log(box.dataset.id)</script>
    </body>
    

5. 定时器-间歇函数

5.1 定时器函数介绍

  • 网页中经常会需要一种功能:每隔一段时间需要自动执行一段代码,不需要我们手动去触发
  • 例如:网页中的倒计时
  • 要实现这种需求,需要定时器函数
  • 定时器函数有两种,下面先介绍间歇函数

5.2 定时器函数基本使用

定时器函数可以开启和关闭定时器

  1. 开启定时器
    setInterval(函数, 间隔时间)
    
    • 作用:每隔一段时间调用这个函数
    • 间隔时间单位是毫秒
  • 例子:
    funcion repeat() {console.log('前端程序员')
    }
    // 每隔一秒调用 repeat 函数
    setInterval(repeat, 1000)
    
  • 注意:
    • 函数名字不需要加括号
    • 定时器返回的是一个id数字
  1. 关闭定时器
    let 变量名 = setInterval(函数, 间隔时间)
    clearInterval(变量名)
    
  • 一般不会刚创建就停止,而是满足一定条件再停止。
  • 例子:
    let timer = setInterval(funcion() {console.log('前端程序员')
    }, 1000)
    clearInterval(timer)
    

相关文章:

【JS】Chapter6-Dom 获取属性操作

站在巨人的肩膀上 黑马程序员前端JavaScript入门到精通全套视频教程&#xff0c;javascript核心进阶ES6语法、API、js高级等基础知识和实战教程 &#xff08;六&#xff09;Dom 获取&属性操作 以下的变量可以将 let 改为 const&#xff1a; let arr [red, green] arr.pu…...

太极培训机构展示服务预约小程序的作用如何

太极是适合男女老幼的&#xff0c;很多地方也有相关的学校或培训机构&#xff0c;由于受众广且不太受地域影响&#xff0c;因此对培训机构来说&#xff0c;除了线下经营外&#xff0c;线上宣传、学员获取和发展也不可少。 接下来让我们看下通过【雨科】平台制作太极教培服务预…...

node使用path模块的基本使用

文章目录 一、path.resolve(常用)二、path.sep三、path.parse其他 一、path.resolve(常用) 由于node 中使用 __dirname 获取的绝对路径是/ ,而我们拼接的路径为‘/’导致路径不统一。 作用&#xff1a;拼接规范的绝对路径 const fs require(fs) const path require(path)// 1…...

我和云栖大会有个约会

前言 云栖大会&#xff08;Alibaba Cloud Computing Conference&#xff09;是中国阿里巴巴集团旗下的云计算技术盛会&#xff0c;旨在推动云计算技术的发展和应用。该大会自2009年首次举办以来&#xff0c;已成为云计算行业内规模最大、影响力最广的会议之一。 云栖大会每年…...

Linux各个发行版之间的关系

Linux各个发行版之间的关系 可以查看链接&#xff1a;Linux Timeline 链接中可以下载PNG或者SVG图片...

第一章 第一行Android代码

一、Android简介 1.android系统架构 linux kernel&#xff08;Linux内核层&#xff09;&#xff1a;提供硬件底层驱动 libraries&#xff08;系统运行库层&#xff09;&#xff1a;提供了主要的特性支持&#xff0c;如SQLite库、Webkit库&#xff1b;还包含android runtime&…...

怎样利用 AI 大模型,辅助研发管理与效能提升?

AI 大模型已经逐渐渗透到各行各业的应用场景中&#xff0c;在软件研发领域也不例外。在软件研发领域&#xff0c;从需求分析到软件设计&#xff0c;从软件开发到测试&#xff0c;以及最后发布上线&#xff0c;AI 在各个环节都发挥着重要作用。10 月 21 日&#xff0c;思码逸首席…...

聊天室的创建

要创建一个聊天室&#xff0c;您需要&#xff1a; 确定聊天室的主题和目的。 选择一个适当的聊天室平台或应用程序&#xff0c;如Discord、Slack、Zoom等。 注册一个账户并创建一个聊天室。 添加您的朋友或家人或需要的人到聊天室中。 设置聊天室的规则和管理机制&#xff…...

大数据信息抽取

随着互联网的广泛应用和技术的不断进步&#xff0c;海量数据被产生、存储和共享。这些数据中包含着宝贵的的信息和知识&#xff0c;二大数据信息抽取是正是为了把这些数据中关键、有用的信息提取出来。 大数据信息抽取就是指通过自动化的方式&#xff0c;从大数据中提取有异议…...

驱动开发11-1 编写IIC驱动-读取温湿度数据

头文件 head.h #ifndef __HEAD_H__ #define __HEAD_H__ #define GET_HUM _IOR(m, 1, int) #define GET_TEM _IOR(m, 0, int) #endif 应用程序 si7006.c #include <stdlib.h> #include <stdio.h> #include <sys/types.h> #include <sys/stat.h> #inc…...

上海中优城市万豪酒店推出全新国际IP童趣主题房,独特住宿体验中国首秀

2023年10月30日&#xff0c;中国上海 – 近日&#xff0c;上海中优城市万豪酒店正式推出由全球品牌娱乐公司孩之宝官方授权打造的小马宝莉和变形金刚主题客房&#xff0c;以创意客房、新奇体验和丰富礼遇&#xff0c;为童游家庭或年轻的动漫迷们开启沉浸式入住之旅&#xff0c;…...

zsh和bash之间互相切换

zsh->bash exec bashbash->zsh exec zsh...

Java - window系统快捷键大全

Ctrl 快捷键 介绍 Ctrl F 在当前文件进行文本查找 &#xff08;必备&#xff09; Ctrl R 在当前文件进行文本替换 &#xff08;必备&#xff09; Ctrl Z 撤销 &#xff08;必备&#xff09; Ctrl Y 删除光标所在行 或 删除选中的行 &#xff08;必备&#xff09; Ctrl X …...

深入理解数据结构(1)—用链表实现栈

栈是一种数据结构&#xff0c;链表也是一种数据结构。它们都是由基础的语法实现的。 如果一个数据结构可以用另外的数据结构来实现&#xff0c;那么可以有力的证明——“数据结构是一种思想”&#xff0c;是一种讲语法组合起来实现某种功能的手段 一、栈的特点——要实现哪些功…...

Jtti:debian安装firewalld错误怎么办

如果在Debian系统上安装Firewalld时出现错误&#xff0c;可以尝试以下步骤来解决问题&#xff1a; 更新软件包列表&#xff1a; 首先确保您的Debian系统的软件包列表是最新的。运行以下命令&#xff1a; sudo apt update 安装Firewalld&#xff1a; 使用以下命令安装Firewalld&…...

如何理解python中的*args和**kwargs

args用于表示可变数量的位置参数&#xff08;Positional Arguments&#xff09; kwargs 用于表示可变数量的关键字参数&#xff08;Keyword Arguments&#xff09;。 *args 来接收不定数量的位置参数 实例: def exampleFunc(*args):print(type(args))for arg in args:print…...

软考之软件工程基础理论知识

软件工程基础 软件开发方法 结构化方法 将整个系统的开发过程分为若干阶段&#xff0c;然后依次进行&#xff0c;前一阶段是后一阶段的工作依据按顺序完成。应用最广泛。特点是注重开发过程的整体性和全局性。缺点是开发周期长文档设计说明繁琐&#xff0c;工作效率低开发前要…...

香港服务器不稳定的几种情况

​  近年来&#xff0c;随着互联网的迅猛发展&#xff0c;香港作为一个重要的网络枢纽地区&#xff0c;扮演着连接中国内地和国际网络的重要角色。一些用户表示在使用香港服务器时可能会遇到不稳定的情况&#xff0c;导致访问困难、加载缓慢甚至无法连接。 为什么香港服务器会…...

报修软件有什么用?企业如何做好设备管理与维护?

在当今的商业环境中&#xff0c;设备设施的维护和管理已经成为企业运营的重要环节。无论是学校、酒店、物业等大型企事业单位&#xff0c;还是运维集成商、制造工厂等企业单位&#xff0c;都需要对设备设施进行有效的管理。报修软件作为一种智能化的解决方案&#xff0c;为设备…...

Go语言的键盘输入和打印输出

键盘输入和打印输出 一、打印输出 1.1 fmt包 fmt包实现了类似C语言printf和scanf的格式化I/O。格式化verb&#xff08;‘verb’&#xff09;源自C语言但更简单。 详见官网fmt的API&#xff1a;https://golang.google.cn/pkg/fmt/ 1.2 导入包 import "fmt"1.3 常…...

基于AT89C51单片机的智能抢答器系统设计与实现

1. 智能抢答器系统概述 在各类知识竞赛和课堂互动中&#xff0c;抢答环节往往是气氛最热烈的部分。传统的手动抢答方式容易产生争议&#xff0c;而基于AT89C51单片机的智能抢答器系统则完美解决了这个问题。这个系统不仅能准确识别最先按下抢答键的选手&#xff0c;还能通过声音…...

[特殊字符] 2026年硕博必看!参考文献引用格式全攻略:从手动调格式到一键智能引用

&#x1f525; 你是否正在为论文的参考文献格式而抓狂&#xff1f;手动调整APA、MLA、GB/T 7714格式&#xff0c;一个标点符号错误就要重新来&#xff1f;本文为2026年的硕博生提供最全面的文献引用工具对比&#xff0c;重点推荐Scholaread一键智能引用功能&#xff0c;支持9种…...

Cursor 3 来袭:编程已不是敲键盘,而是指挥智能体!

2026 年 4 月&#xff0c;AI 编程工具巨头 Cursor 正式发布新一代产品 Cursor 3。与传统的代码编辑器不同&#xff0c;Cursor 3 将开发者的交互界面从“键盘敲击”转向了“智能体指挥”。它不再把 VS Code 视为核心工作台&#xff0c;而是将其降级为一种“备选方案”。该工具的…...

深入拆解ISP Pipeline:Tuning工程师如何像侦探一样排查图像问题?

深入拆解ISP Pipeline&#xff1a;Tuning工程师如何像侦探一样排查图像问题&#xff1f; 当一张照片出现偏色、噪点或细节丢失时&#xff0c;普通用户可能只会抱怨"拍得不好"&#xff0c;而ISP Tuning工程师看到的却是一个待解的谜题。就像侦探通过蛛丝马迹还原案件真…...

.NET 9边缘测试黄金标准(微软内部CI/CD流水线首次公开):含12项必验指标与3种硬件故障注入模板

第一章&#xff1a;.NET 9边缘部署测试的演进与战略定位.NET 9标志着微软在云边协同架构上的关键跃迁——其原生支持AOT编译、精简运行时&#xff08;Microsoft.NETCore.App.Runtime.Minimal&#xff09;及轻量级容器镜像&#xff0c;为边缘场景下的确定性启动、低内存占用与快…...

十大AI写作工具迎来深度评测,AIGC论文助手从功能性、稳定性等维度出发,量化分析其核心表现。

工具名称 核心优势 适用场景 aicheck 快速降AIGC率至个位数 AIGC优化、重复率降低 aibiye 智能生成论文大纲 论文结构与内容生成 askpaper 文献高效整合 开题报告与文献综述 秒篇 降重效果显著 重复率大幅降低 一站式论文查重降重 查重改写一站式 完整论文优化…...

汽车电子电气架构演进与关键技术解析

1. 从分布式到域控制&#xff1a;汽车电子电气架构的演进之路 上世纪70年代的汽车电子系统简单得令人难以置信——只有启动装置、车灯和点火系统等基础功能。我拆解过一辆1982年的老式轿车&#xff0c;整个电子系统仅由3个继电器和若干保险丝组成。而如今&#xff0c;一辆高端智…...

NifSkope终极指南:为什么这款免费开源3D模型编辑器能彻底改变你的游戏模组制作体验

NifSkope终极指南&#xff1a;为什么这款免费开源3D模型编辑器能彻底改变你的游戏模组制作体验 【免费下载链接】nifskope A git repository for nifskope. 项目地址: https://gitcode.com/gh_mirrors/ni/nifskope 你是否曾为《上古卷轴》或《辐射》系列的模型文件格式头…...

93.91%压缩率背后的技术革命:CompressO如何解决企业级视频处理的效率困境

93.91%压缩率背后的技术革命&#xff1a;CompressO如何解决企业级视频处理的效率困境 【免费下载链接】compressO Convert any video/image into a tiny size. 100% free & open-source. Available for Mac, Windows & Linux. 项目地址: https://gitcode.com/gh_mirr…...

从删库到跑路?Oracle DBA必备的5种安全删除操作手册(附实战命令)

Oracle DBA安全删除操作全指南&#xff1a;从原理到实战 引言&#xff1a;为什么安全删除如此重要&#xff1f; 在数据库管理领域&#xff0c;删除操作可能是最令人胆战心惊的任务之一。想象一下这样的场景&#xff1a;凌晨三点&#xff0c;你接到紧急电话&#xff0c;因为一个…...