DOM的重要核心

news/2024/9/14 1:44:51/ 标签: 前端, javascript, html
htmledit_views">

目录

DOM的创建

1.document.write

2.innerHTML

3.createElement

2.增加

3.删除

4.改

5.查

6.属性操作

7.事件操作

8.注册事件

8.1传统注册方式

8.2addEventListener事件监听方式

基本语法

监听点击事件

监听多个事件

移除事件监听器


DOM的创建

1.document.write

用途:document.write() 方法直接向 HTML 文档中写入内容。如果文档已经加载完成(即页面已经加载完毕),使用 document.write() 会覆盖整个页面的内容

2.innerHTML

用途:innerHTML 属性用于获取或设置元素的HTML内容

html" title=javascript>javascript">document.getElementById('myDiv').innerHTML = '<p>这是一个新的段落。</p>';

3.createElement

用途:createElement() 方法用于动态创建新的DOM元素

html" title=javascript>javascript">var newElement = document.createElement('p');  
newElement.textContent = '这是一个新的段落。';  
document.body.appendChild(newElement);

区别

  • innerHTML比document.write()更加灵活,因为它允许你精确地控制DOM的某一部分,而不是整个页面。
  • 与innerHTML相比,createElement提供了更细粒度的控制,因为它允许你逐个创建和配置元素,然后再将它们添加到DOM中。这对于构建复杂的DOM结构特别有用。

2.增加

1.appendChild

html" title=javascript>javascript">   var p=document.createElement("p");//添加元素节点 node.appendChild(newNode)document.body.appendChild(p);p.appendChild(document.createTextNode("我是新创建的节点"));

2.insertBefore

html" title=javascript>javascript">    ul.insertBefore(li,ul.children[0]);

3.删除

parentNode .removeChild

html" title=javascript>javascript">   for(var i=0;i<a.length;i++){a[i].onclick=function(){var li=this.parentNode;ul.removeChild(li);}

4.改

参考文章https://mp.csdn.net/mp_blog/creation/editor/141200432

 主要修改dom的元素属性, dom元素的内容、属性,表単的值等 

1. 修改元素属性: src、 href、 title等

2.修改普通元素内容: innerHTML、 innerText

3.修改表単元素: value、type、 disabled等

4.修改元素祥式: style、 className
 

5.查

主要获取查询dom的元素

1. DOM提供的API方法: getElementByld、 getElementsByTagName 古老用法不太推荐

2. H5提供的新方法 : querySelector、 querySelectorAll 提倡

3.利用子节点操作获取元素:父(parentNode)、子( childern)、 兄 (previousElementSibling 、nextElementSibling)

6.属性操作

主要针対于自定义属性。

1.setAttribute(attributeName, value):设置dom的属性値

html" title=javascript>javascript">var elem = document.getElementById("myElement");  
elem.setAttribute("title", "这是新的标题");

2. getAttribute(attributeName) :得到dom的属性値

html" title=javascript>javascript">var elem = document.getElementById("myElement");  
var title = elem.getAttribute("title");  
console.log(title); // 输出:这是新的标题

3. removeAttribute(attributeName)移除属性

html" title=javascript>javascript">var elem = document.getElementById("myElement");  
elem.removeAttribute("title");

7.事件操作

鼠标事件

鼠标事件触发条件
click点击
dblclick双击
mousedown鼠标按下
mouseup鼠标松开
mousemove鼠标移动
mouseenter鼠标进入元素
mouseleave鼠标离开元素
contextmenu网页中禁止鼠标右键菜单和禁止选中文字
鼠标事件补充:
  • 通过CSS:对于不支持selectstart事件的浏览器,你可以使用CSS的user-select属性来禁止选中文本
  • selectstart禁止选中文字事件
html" title=javascript>javascript"><head>  <title>禁止右键和选中</title>  <style>  body {  -webkit-user-select: none; /* Chrome, Safari, Opera */  -moz-user-select: none;    /* Firefox */  -ms-user-select: none;     /* IE 10 and IE 11 */  user-select: none;         /* Standard syntax */  }  </style>  <script>  document.addEventListener('DOMContentLoaded', function() {  // 禁止整个文档的右键菜单  document.body.addEventListener('contextmenu', function(e) {  e.preventDefault();  }, false);  // 禁止整个文档的文本选中(虽然CSS已经处理了大部分情况)  document.body.addEventListener('selectstart', function(e) {  e.preventDefault();  }, false);  });  </script>  
</head>  
<body>  <p>这里不能右键,也不能选中文字。</p>  
</body>  

 鼠标事件对象

常用属性

鼠标事件对象包含了许多有用的属性,以下是一些最常用的:

常见属性说明
type返回事件的类型,如 "mouseenter""mouseleav“
target返回触发事件的元素
currentTarget返回其事件监听器触发该事件的元素
clientX/clientY鼠标指针在视口中的X和Y坐标(不包括滚动条滚动的部分)
pageX/pageY鼠标指针在页面上的X和Y坐标(包括滚动条滚动的部分)
screenX 和 screenY鼠标指针在屏幕上的X和Y坐标
button指示哪个鼠标按钮被点击

ctrlKeyshiftKeyaltKeymetaKey

(在Mac上是Cmd键,在Windows上是Windows键)

表示事件发生时是否同时按下了这些修饰键

代码示例

html" title=javascript>javascript">console.log('鼠标的clientX坐标:', event.clientX);  console.log('鼠标的clientY坐标:', event.clientY);  console.log('鼠标的pageX坐标:', event.pageX);  console.log('鼠标的pageY坐标:', event.pageY);

键盘事件

键盘事件触发条件
keydown键盘按下
keyup键盘松开
keypress按键被按下并释放一个键

keydown 和keypress区别:

  • keydown下键盘上的任意键时触发,keypress对于功能键不触发 
  • 大小写敏感性:keypress事件能够区分字母的大小写(它返回的是字符的ASCII码值),而keydown事件则不区分(它返回的是按键的物理码,将大写和小写视为同一个键)

代码示例

html" title=javascript>javascript">    <script>// 键盘按下事件document.addEventListener('keydown', function(e) {if(e.key === 'Enter'){alert('按下了回车键');}})//  键盘按住事件document.addEventListener('keyup', function(e) {if(e.key === 'Shift'){alert('按住了Shift键');}   else if(e.key === 'Control'){alert('按住了Control键');}   else if(e.key === 'Alt'){alert('按住了Alt键');}})// // ��标按下事件document.addEventListener('keypress', function(e) {if(e.key === 'a'){alert('按下了a键');}   else if(e.key === 'b'){alert('按下了b键');}   else if(e.key === 'c'){alert('按下了c键');}})</script>
键盘事件属性
键盘事件对象说明
key返回一个表示实际按下的键的字符串
code返回一个表示按键物理位置的字符串
altKey、ctrlKey、shiftKey、metaKey(在Mac上是Cmd键,在Windows上是Windows键)这些布尔属性表示事件发生时是否按下了对应的修饰键
charCode(仅限keypress事件)在keypress事件中,这个属性表示按键的Unicode字符编码
location表示按键在物理键盘上的位置(如果有多个相同类型的键,如左右两侧的Shift键)
repeat(仅限keydown事件)如果事件是由于用户持续按住键而产生的自动重复,则为true;否则为false

表单事件 

表单事件触发条件
focus元素获得焦点
blur元素失去焦点
change表单元素的内容改变

页面事件 

页面事件触发条件
load页面加载完成
resize窗口大小改变
scroll页面滚动

8.注册事件

8.1传统注册方式

  • 利用on开头的事件onclick
  • <button οnclick="alert('hi~")></button>
  • btn.οnclick=function(){}
  • 特点:注册事件的唯一性
  • 同一个元素同一个事件只能设置一个处理函数,最后注册处理函数将会覆盖前面注册处理的函数

8.2addEventListener事件监听方式

eventTarget . addEventListener ()方法将指定的监听器注册到eventTarget (目标对象)上,当该对象触发指定的事件时,就会执行事件处理函数。

基本语法

html" title=javascript>javascript">element.addEventListener(event, function, useCapture);

参数: 

  • element: 要添加事件监听器的 DOM 元素。
  • event: 要监听的事件类型(如 "click", "mouseover", "keydown" 等)。
  • function: 当事件发生时,要执行的函数。这个函数通常被称为事件处理函数或事件监听器。
  • useCapture (可选): 一个布尔值,指定事件是否在捕获或冒泡阶段执行。默认为 false,即事件在冒泡阶段执行。

监听点击事件

html" title=javascript>javascript">// 获取元素  
var button = document.getElementById("myButton");  // 添加点击事件监听器  
button.addEventListener("click", function() {  alert("按钮被点击了!");  
});

监听多个事件

html" title=javascript>javascript">var div = document.getElementById("myDiv");  // 监听点击事件  
div.addEventListener("click", function() {  console.log("点击了 div");  
});  // 监听鼠标移入事件  
div.addEventListener("mouseover", function() {  console.log("鼠标移入了 div");  
});

移除事件监听器

使用 removeEventListener 方法可以移除之前通过 addEventListener 添加的事件监听器。

html" title=javascript>javascript">var button = document.getElementById("myButton");  function handleClick() {  alert("按钮被点击了!");  
}  // 添加事件监听器  
button.addEventListener("click", handleClick);  // 移除事件监听器  
button.removeEventListener("click", handleClick);

http://www.ppmy.cn/news/1515842.html

相关文章

深度学习入门:循环神经网络------RNN概述,词嵌入层,循环网络层及案例实践!(万字详解!)

目录 &#x1f354; RNN 概述 1.1 循环神经网络 1.2 自然语言处理 &#x1f354; 词嵌入层 2.1 词嵌入层的使用 2.2 关于词嵌入层的思考 2.3 小节 &#x1f354; 循环网络层 3.1 RNN 网络原理 3.1.1 RNN计算过程 3.1.2 如何计算神经元内部 3.2 PyTorch RNN 层的使用…

虚拟机安装centos7-桥接模式

1、打开虚拟机&#xff0c;点击文件&#xff0c;选择新建虚拟机 2、选择典型&#xff0c;点击下一步 3、选择稍后安装操作系统&#xff0c;点击下一步 4、选择系统类型及版本&#xff0c;点击下一步&#xff0c;因centos7是Linux操作系统&#xff0c;且是64位的&#xff0c;所以…

唯大数据(大模型)论阻碍智能领域的创新吗?

唯大数据&#xff0c;即将大数据视为智能领域创新的唯一或主要驱动力&#xff0c;可能会带来一些挑战和限制。尽管大数据在智能系统中提供了丰富的信息和洞察&#xff0c;但过度依赖大数据也可能导致以下几个问题&#xff1a; 1、数据质量和偏差&#xff1a;大数据往往包含大量…

SpringMVC核心机制环境搭建

文章目录 1.SpringMVC执行流程1.基础流程图2.详细流程图 2.安装Tomcat1.下载2.解压到任意目录即可3.IDEA配置Tomcat1.配置Deloyment2.配置Server 3.创建maven项目1.创建sun-springmvc模块&#xff08;webapp&#xff09;2.查看是否被父模块管理3.pom.xml引入依赖4.目录5.SunDis…

Xshell链接本地20.04Ubuntu虚拟机

一、打开虚拟机设置选择自定义-net8 二、打开虚拟网络编辑器&#xff0c;点击更改设置 三、打开网络设置&#xff0c;如图操作 四。打开虚拟机&#xff0c;进入终端&#xff0c;输入ifconfig 五、su root进入root模式&#xff0c;配置静态网卡 # 备份配置文件 cd /etc/netpla…

大数据背景下基于Python的牛油果销售数据可视化分析

注&#xff1a;源码在最后&#xff0c;只是一次实验记录&#xff0c;不合理的地方自行修改。 一 研究背景及意义 21世纪以来&#xff0c;随着科学技术的进步&#xff0c;人们的生活水平也随之大幅提升提高。在科技和经济快速发展下&#xff0c;全球已经进入了大数据时代。大数…

Excel地址

题目描述 Excel 单元格的地址表示很有趣&#xff0c;它使用字母来表示列号。 比如&#xff0c; A 表示第 1 列&#xff0c; B 表示第 2 列&#xff0c; Z 表示第 26 列&#xff0c; AA 表示第 27 列&#xff0c; AB 表示第 28 列&#xff0c; BA 表示第 53 列&#xff…

如何从单点到集群配置Eureka:最佳实践与配置详解

如何从单点到集群配置Eureka&#xff1a;最佳实践与配置详解 1. 引言 什么是Eureka&#xff1f; Eureka是Netflix开源的服务发现和注册中心&#xff0c;广泛应用于微服务架构中。它允许各个服务实例在启动时注册到Eureka Server&#xff0c;并通过Eureka Client获取其他服务…

MySQL面试常问问题

MySQL为什么默认存储引擎是InnoDB&#xff1f; 从存储数据角度来讲&#xff0c;innodb采取的是在一个文件中用B树结构存储索引和完整数据&#xff08;即聚集索引&#xff09;&#xff0c;减少了拿着索引去另一个文件寻找完整数据的过程&#xff0c;提高了查询的效率。 支持事…

基于Android Studio 多功能记事本-MySQL版

目录 一、项目演示 二、开发环境 三、项目详情 四、项目完整源码 一、项目演示 基于Android Studio 多功能记事本--MySQL版 二、开发环境 三、项目详情 1.启动页 这段代码主要实现了以下功能&#xff1a; 1. **延迟跳转**&#xff1a;在 StartActivity 中&#xff0c;使用…

GStreamer 简明教程(五):Pad 相关概念介绍,Pad Capabilities/Templates

系列文章目录 GStreamer 简明教程&#xff08;一&#xff09;&#xff1a;环境搭建&#xff0c;运行 Basic Tutorial 1 Hello world! GStreamer 简明教程&#xff08;二&#xff09;&#xff1a;基本概念介绍&#xff0c;Element 和 Pipeline GStreamer 简明教程&#xff08;三…

配置PXE预启动执行环境:使用PXE装机服务器网络引导装机

文章目录 PXE概述PXE批量部署的优点基本的部署过程搭建的前提条件 搭建配置PXE装机服务器1. 准备 CentOS 7 安装源&#xff08;YUM 仓库&#xff09;2. 安装并启用 TFTP 服务3. 安装并启用 DHCP 服务4. 准备 Linux 内核和初始化镜像文件5. 准备 PXE 引导程序6. 安装 FTP 服务并…

每天一道C语言精选编程题之求字符串长度

题目描述 写⼀个函数Strlen&#xff0c;可以求字符串⻓度&#xff0c;注&#xff1a;字符串的结束标志是 \0 输⼊⼀个字符串&#xff08;字符串⻓度⼩于等于30&#xff0c;中间不包含空格&#xff09;&#xff0c;使⽤Strlen函数可以求字符串的长度&#xff0c;并返回。 解法…

如何使用Web Scraper爬虫抓取数据?

Web Scraper是一个基于Chrome/火狐浏览器的插件&#xff0c;能够在网页上自动爬取数据&#xff0c;提供了丰富的配置&#xff0c;支持自动翻页、登录认证、JavaScript渲染等等&#xff0c;可以解决多数爬虫难题。 Web Scraper的安装也很简单&#xff0c;在Chrome应用商店里搜索…

【LLM大模型论文日更】| 格式胜过内容:揭示大型语言模型的提示效应

论文&#xff1a;https://arxiv.org/pdf/2408.08780代码&#xff1a;未开源机构&#xff1a;北京大学领域&#xff1a;提示学习&#xff0c;上下文学习发表&#xff1a;arXiv 研究背景 研究问题&#xff1a;这篇文章探讨了在上下文学习&#xff08;ICL&#xff09;中&#xf…

AJAX(5)——Promise

Promise Promise对象用于表示一个异步操作的最终完成或失败及其结果值 语法&#xff1a; //创建Promise对象const p new Promise((resolve, reject) > {//执行异步代码setTimeout(() > {// resolve(成功结果)reject(new Error(失败结果))}, 2000)})//获取结果p.then(r…

c++枚举类型StarPU实现矩阵乘

1) 枚举类型 #pragma once #include<stdio.h> #include<stdlib.h> #include<string.h> #include<windows.h> #include<iostream> #include <time.h>enum Color {RED, //RED0GREEN, //GREEN1BLUE //BLUE2 }; int main() {//定义数据…

Linux网络编程:多路转接--poll/epoll

1. poll poll也是一种多路转接的方案&#xff0c;解决了select的fd有上限和每次调用都要重新设置关心的fd的问题。 2. poll接口 #include int poll(struct pollfd* fds, nfds_t nfds, int timeout); 参数&#xff1a;fds&#xff1a;可以看成是动态数组/数组/结构体数组 nfds&…

Selenium + Python 自动化测试21(PO+HTML+Mail)

我们的目标是&#xff1a;按照这一套资料学习下来&#xff0c;大家可以独立完成自动化测试的任务。 上一篇我们讨论了PO模式并举例说明了基本的思路&#xff0c;今天我们继续学习。 本篇文章我们综合一下之前学习的内容&#xff0c;如先将PO模式和我们生成HTML报告融合起来&am…

使用redis设计延迟队列

目录 延迟队列概念与重要性 定义&#xff1a;延迟队列的基本概念 重要性&#xff1a;延迟队列在处理异步任务中的关键作用 图表&#xff1a;延迟队列的工作流程图 ​编辑延迟队列设计案例 背景介绍 设计目标 系统架构 设计要点 现有物理拓扑 图表&#xff1a;有赞延迟…