【JavaScript】DOM 学习总结-基础知识

news2024/12/23 9:49:55

获取元素方法:

// 获取三个非常规的标签
console.log(document.documentElement)
console.log(document.head)
console.log(document.body)

通过id/class获取:getElementById / getElementsByClassName

// 获取常规的用id,class,tag 
var box=document.getElementById("box")
box.innerHTML = "222"
var lis=document.getElementsByClassName("lis")
console.log(lis)

通过tag获取:getElementsByTagName

var lis=document.getElementsByTagName("li")
console.log(lis)

注:通过tag获取到的范围比id和class要大,如果所有的li标签都是一个样式,可以使用tag,如果单独设置样式,只能用id或者class
注意:JavaScript给变量命名不要用HTML、css的标签名,比如:value、name、li
特殊:通过name获取:

var name1=document.getElementsByName("username")

通用方法:querySelector

// querySelector:匹配遇到的第一个对象,也只能返回一个对象
var box1=document.querySelector("#box")
console.log(box1)

// querySelectorAll:获取所有元素
var lis=document.querySelectorAll("ul li.lis")
console.log(lis)

操作元素文本内容:

innerHTML指的是从对象的起始位置到终止位置的全部内容,包括Html标签。
innerText 指的是从起始位置到终止位置的内容,但它去除Html标签。
同时,innerHTML 是所有浏览器都支持的,innerText 是IE浏览器和chrome 浏览器支持的,Firefox浏览器不支持。其实,innerHTML 是W3C 组织规定的属性;而innerText 属性是IE浏览器自己的属性,不过后来的浏览器部分实现这个属性罢了。
nnerHTML获取的是文本加上标签,而innerText获取的就是纯文本,并且innerText不进行解析,只会当做字符串全部显示

在这里插入图片描述
在这里插入图片描述

操作元素样式和类名:

1.行内式:通过id名+属性

      <div id="box1" style="width: 100px;color: blue; background-color: bisque;" >hello</div>
      
//获取行内样式:style
    console.log(box1.style.width);
    // 注意:有些元素属性需要采用驼峰写法或者使用中括号
    console.log(box1.style.backgroundColor)
    console.log(box1.style["backgroundColor"])

    //更改行内样式:style
    box1.style.width="200px";
    box1.style.backgroundColor="yellow"
    console.log(box1.style["backgroundColor"])

2.内部式、外部式

//内部样式,外部样式   getComputedStyle 获取,但是不能更改
console.log(window.getComputedStyle(box1).height)
console.log(window.getComputedStyle(box1).backgroundColor)

操作元素类名:
1.className

<style>
        .item{
            height: 200px; width: 200px;
            background-color: palevioletred;
            color: aqua;
            border-radius: 10px;
        }
    </style>
</head>
<body>
    <div class="item" id="box1">
<p style="text-align: center; line-height: 200px;">hello !</p>
    </div>
</body>
<script>
    //.className
    // console.log(box1.className)
    box1.className=""

在这里插入图片描述
缺点在于赋值时不进行去重处理
2.classList:
classList拥有自动去重的能力
在这里插入图片描述
删除:

 box1.classList.remove("item1")

用自定义属性dataset操作元素

<!-- 规定自定义属性写法为:data-*** -->
<div  id="haha" data-hefan="111" data-he="222"></div>
console.log(haha);
// 获取自定义属性:dataset
console.log(haha.dataset);
//添加自定义属性:
haha.dataset.name = "hello"
//删除自定义属性
delete haha.dataset.name;

DOMStringMap 接口在 HTMLElement.dataset 属性中被用到,被用于容纳和展示元素的自定义属性。
DOMStringMap 接口在 HTMLElement.dataset 属性中被用到,被用于容纳和展示元素的自定义属性。

获取节点

在 HTML DOM 中,所有事物都是节点。DOM 是被视为节点树的 HTML。
根据 W3C 的 HTML DOM 标准,HTML 文档中的所有内容都是节点:
整个文档是一个文档节点
每个 HTML 元素是元素节点
HTML 元素内的文本是文本节点
每个 HTML 属性是属性节点
注释是注释节点
在这里插入图片描述

孩子节点:

1.childNodes
在这里插入图片描述
空格也算是文本节点,注释是注释节点。一共是三个空格文本节点,一个元素结点(p),一个注释节点
2.children
在这里插入图片描述
获取孩子节点:firstChild firstElementChild
在这里插入图片描述

兄弟节点:

获取兄弟节点:previousSibling previousElementSibling
在这里插入图片描述
previousSibling:获取的是相邻兄弟的任何节点,空格也算是文本节点【data: "\n 】
previousElementSibling:获取的是元素节点,那只有div是元素节点
获取下一个兄弟节点:nextSibling nextElementSibling

父母节点:

获取父母节点:parentNode parentElement
在这里插入图片描述

节点操作:

在这里插入图片描述

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述
在某一个元素前面插入一个节点:
insertBefore:(要插入的元素,被前插的元素id名)

 <div id="box1">
        <div id="box2">jaja</div>
    </div>

在这里插入图片描述

删除节点:

 box1.removeChild(box2);

删除自身,包括孩子 box1.remove()
在这里插入图片描述
在这里插入图片描述

元素节点类型:

在这里插入图片描述

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

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

相关文章

Android 自定义Activity的主题

一. 前言 当在某个app中做一个新界面时, 我们要考虑一下主题风格相符合一致. 本篇文章讲解的是,如何新创建的Activity 与整个app主题符合, 特别是状态栏的颜色需要和这个app的状态栏颜色保持一致. 在读本篇文章之前, 可以移步一下笔者之前写的文章:Android style&#xf…

代码随想录算法训练营第十一天字符串 java :20. 有效的括号 1047. 删除字符串中的所有相邻重复项 150. 逆波兰表达式求值

文章目录Leetcode 20. 有效的括号题目详解数据结构 双端队列(deque)Deque有三种用途&#xff1a;思路报错Ac代码Leetcode1047. 删除字符串中的所有相邻重复项题目详解数据结构 ArrayDeque类思路AC代码150. 逆波兰表达式求值题目详解报错难点AC代码收获Leetcode 20. 有效的括号 …

系分 - 系统设计

个人总结&#xff0c;仅供参考&#xff0c;欢迎加好友一起讨论 文章目录系分 - 系统设计考点摘要系统设计软件设计软件架构设计结构化设计概要设计详细设计处理流程设计流程工作流活动及其所有者工作项工作流管理系统WFMS的基本功能WFMS的组成WRM流程设计工具用户界面设计/人机…

python算法与数据结构1-算法、数据结构、链表

目录1、算法的概念1.1 举例&#xff1a;1.2 算法的五大特性&#xff1a;1.3 时间复杂度1.4 空间复杂度2、数据结构2.1 内存的存储结构2.2 数据结构的分类2.3 顺序表存储方式3、链表3.1链表实现3.2链表的方法3.3链表增加节点3.4链表删除节点3.5链表总结1、算法的概念 算法与数据…

(Java高级教程)第三章Java网络编程-第三节:UDP数据报套接字(DatagramSocket)编程

文章目录一&#xff1a;Java数据报套接字通信模型二&#xff1a;相关API详解&#xff08;1&#xff09;DatagramSocket&#xff08;2&#xff09;DatagramPacket三&#xff1a;UDP通信示例一&#xff1a;客户端发送什么服务端就返回什么&#xff08;1&#xff09;代码&#xff…

k8s之ConfigMap和secret

写在前面 我们知道k8s的数据都是存储到kv数据库etcd中的&#xff0c;那么我们程序中使用到各种配置信息是否可以也存储到etcd&#xff0c;然后在pod中使用呢&#xff1f;是可以的&#xff0c;k8s为了实现将自定义的数据存储到etcd&#xff0c;定义了ConfigMap 和secret两种API…

《后端技术面试 38 讲》学习笔记 Day 01

《后端技术面试 38 讲》学习笔记 Day 01 学习目标 在2022年春节将至&#xff08;半个月&#xff09;&#xff0c;适合在这个冬天里&#xff0c;温故知新。通过学习一门覆盖面较广的课程&#xff0c;来夯实基础&#xff0c;完善自己的知识体系&#xff0c;是一个很棒的选择。 …

LCHub:未来,低代码产品矩阵是500强企业的绝佳选择

近日,国内知名咨询机LCHub发布2022《中国大型企业数字化升级路径研究》。 报告认为由于大型企业的数字化需求旺盛、购买力充足,因此国内成熟的数字化服务商普遍以大型企业为核心客户。大型企业与数字化服务商的供需磨合决定了我国数字化市场的形态,造就了我国数字化市场与海…

go map 源码逐行阅读

map粗略介绍 源码开头注释&#xff1a; A map is just a hash table. The data is arranged into an array of buckets. Each bucket contains up to 8 key/elem pairs. The low-order bits of the hash are used to select a bucket. Each bucket contains a few high-order…

Linux学习笔记——RabbitMQ安装部署

5.4、RabbitMQ安装部署 5.4.1、简介 RabbitMQ是一款知名的开源消息列队系统&#xff0c;为企业提供消息的发布、订阅、点对点传输等消息服务。 RabbitMQ在企业开发中十分常见&#xff0c;课程为大家演示快速搭建RabbitMQ环境。 5.4.2、安装 RabbitMQ在yum仓库中的版本比较老…

用于从单细胞FRET数据中提取灵敏度分布的Matlab代码

目录 &#x1f4a5;1 概述 &#x1f4da;2 运行结果 &#x1f389;3 参考文献 &#x1f468;‍&#x1f4bb;4 Matlab代码 &#x1f4a5;1 概述 对于分子生物学来讲&#xff0c;生物分析手段的发展&#xff0c;是阐明机理的必要条件。在研究分子间相互作用的道路上&#xf…

Leetcode - 106 - 相交链表

160. 相交链表 题目描述 给你两个单链表的头节点 headA 和 headB &#xff0c;请你找出并返回两个单链表相交的起始节点。如果两个链表不存在相交节点&#xff0c;返回 null 。 图示两个链表在节点 c1 开始相交&#xff1a; 题目数据 保证 整个链式结构中不存在环。 注意&am…

【阶段三】Python机器学习04篇:机器学习项目实战:多元线性回归模型、岭回归模型与套索回归模型

本篇的思维导图: 一元线性回归的数学原理 一元线性回归模型又称为简单线性回归模型,其形式可以表示为如下所示的公式。 y=ax+b 其中,y为因变量,x为自变量,a为回归系数,b为截距。 如下图所示,其中y(i)为实际值,y(i)为预测值,一元线性回归的目的就是拟合出一…

Vision-Only Robot Navigation in a Neural Radiance World

Paper name Vision-Only Robot Navigation in a Neural Radiance World Paper Reading Note URL: https://arxiv.org/abs/2110.00168 TL;DR RA-L 2022 文章&#xff0c;提出在 NeRF 表达的环境中进行机器人导航及循迹任务的方法 Introduction 背景 基于 on-board 传感器…

HTML与CSS基础(五)—— CSS布局(盒子模型)、PxCook使用

目标能够认识 盒子模型 的组成部分 能够掌握盒子模型的 边框、内边距、外边距 的作用及简写形式能够计算盒子的 实际大小 能够了解 外边距折叠现象&#xff0c;并知道如何解决 盒子塌陷问题一、PxCook的基本使用1. 通过软件打开设计图① 打开软件 ② 拖拽入设计图 ③ 新建项目2…

Acwing---99.激光炸弹

激光炸弹1.题目2.基本思想3.代码实现1.题目 地图上有 NNN 个目标&#xff0c;用整数 Xi,YiXi,YiXi,Yi 表示目标在地图上的位置&#xff0c;每个目标都有一个价值 WiWiWi。 注意&#xff1a;不同目标可能在同一位置。 现在有一种新型的激光炸弹&#xff0c;可以摧毁一个包含 …

Java中常用API总结(4)—— Object类(含实例解读和源码阅读)

Object类一、前言二、概述1.API帮助文档2.使用方法三、常用方法1.toString方法1️⃣格式2️⃣实例3️⃣源码阅读4️⃣快捷键重写方法2.equals方法1️⃣格式2️⃣实例3️⃣源码阅读4️⃣重写方法3.对象克隆四、结语一、前言 本文将讲述有关于Object类相关知识点 二、概述 1.A…

C语言文件操作的细节

目录 文本文件和二进制文件 概念 一个数据在内存中是怎么存储的呢&#xff1f; 通过VS2013可以查看二进制数值 文件读取结束的判定 文件缓冲区 文本文件和二进制文件 概念 根据数据的组织形式&#xff0c;数据文件被称为文本文件或者二进制文件。 数据在内存中以二进制的…

YOLOv5 以txt 或json格式输出预测结果

YOLOv5 以txt 或json格式输出预测结果1.YOLOv5源码以多种格式输出预测结果1.run函数——传入参数2.run函数——保存打印2.YOLOv5以.txt格式输出预测结果1.执行以下代码就可以得到以.txt格式输出预测结果2.输出格式&#xff1a;3.YOLOv5以.json格式输出预测结果1.需要在源码中加…

零售行业交易数据分析(3)——群组/同期群分析(留存率分析)

内容简介 本文介绍了群组分析&#xff08;同期群分析&#xff09;的方法以及Python实现过程&#xff0c;并继续对一家零售公司的交易数据进行用户留存分析和可视化。 本系列的文章&#xff1a; 《零售行业交易数据分析&#xff08;1&#xff09;——客户终身价值(CLTV)计算和…