WEB前端07-DOM对象

news2024/11/15 7:42:36
DOM模型
  • 1.DOM概念

文档对象模型属于BOM的一 部分,用于对BOM中的核心对象document进行操作,它是一种与平台、语言无关的接口,允许程序和脚本动态地访问或更新HTML、XML文档的内容、结构和样式,且提供了一系列的函数和对象来实现访问、添加、修改及删除操作。

  • 2.DOM树

DOM将网页中文档的对象关系规划为节点层级,构成它们之间的等级关系,这种各对象间的层次结构被 称为节点树。一个文档的树形结构是由各种 不同的节点组成,Html代表根 节点。除了根节点以外,每个 节点都有一个父节点;每个节 点也可以有许多子节点;具有 相同父节点的节点叫兄弟节点

<!DOCTYPE html>
<html lang="en">
<head>
   <title>DOM TREE</title>
</head>
<body>
    <h1>DOM 模型</h1>
    <ul>
        <li></li>
        <li></li>
    </ul>
</body>
</html>

image-20240717174055145

  • 3.DOM基本组成:
核心DOM对象
* Document:文档对象
* Element:元素对象
* Attribute:属性对象
* Text:文本对象
* Comment:注释对象

* Node:节点对象,其他5个的父对象
  • 4.Document文档对象

访问指定元素的方法

**方法一:**可以通过id、name、class及标签名来访问指定的元素。

类型方法
document.getElementById()获取拥有指定ID的第一个元素对象的引用
document.getElementsByName()获取带有指定名称的元素对象集合。返回值是一个数组
document.getElementsByTagName()获取带有指定标签名的元素对象集合。返回值是一个数组
document.getElementsByClassName()获取指定class的元素对象集合。返回值是一个数组

**方法二:**访问指定的元素的父,子,兄弟元素

image-20231230195347471

值得注意的是:在选用方法二时,一般会有默认空白的注释标签

创建其他DOM对象

document.createAttribute(name)
document.createComment()
document.createElement()
document.createTextNode()
  • 5.Element元素对象

获取:document.createElement()

方法:

1. removeAttribute("属性名"):删除属性
2. setAttribute("属性名", "属性值"):设置属性
  • 6.Node节点对象

所有dom对象都可以被认为是一个节点

方法:

* appendChild():向节点的子节点列表的结尾添加新的子点。
* removeChild()	:删除(并返回)当前节点的指定子节点。
* replaceChild():用新节点替换一个子节点。

属性:

image-20231230195347471

  • 案例:动态表格

实现了一个动态表格功能,用户可以通过输入编号、姓名和性别后点击提交按钮,将输入的数据动态添加为表格的新行。每行包含编号、姓名、性别和一个可点击的删除操作,点击删除链接即可移除对应行。JavaScript负责创建新的表格行和处理删除操作,使得用户可以实时管理和更新表格中的数据。

image-20240718184920943

//添加行功能总结:
JavaScript代码通过以下步骤实现了添加新行的功能:
获取用户在输入框中输入的编号、姓名和性别。
创建新的表格行 (<tr>) 和单元格 (<td>)。
为每个单元格添加用户输入的数据作为文本节点。
创建一个带有"删除"文本的链接 (<a>),设置其点击事件为调用删除函数。
将创建的单元格依次添加到新的表格行中。
将新创建的表格行添加到现有表格的末尾,实现动态添加数据行的效果。

//删除行功能总结:
JavaScript代码通过以下步骤实现了删除行的功能:
编写一个删除函数 delTr(obj),该函数接受一个参数 obj,代表被点击的删除链接元素 (<a>)。
通过 obj.parentNode.parentNode 获取到要删除的表格行 (<tr>)。
使用 removeChild 方法从表格中移除获取到的表格行 (<tr>),实现了点击删除链接后删除对应的数据行。
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>动态表格</title>
    <style>
        .div_1 {
            text-align: center;
        }

        table, td, th {
            border: 1px solid;
        }

        table {
            margin: auto;
        }

        td, th {
            width: 150px;
        }

        caption {
            font-size: 30px;
        }

    </style>
</head>
<body>
    <div class="div_1">
        <input type="text" name="id" id="id" placeholder="请输入编号">
        <input type="text" name="name" id="name" placeholder="请输入用户名">
        <input type="text" name="sex" id="sex" placeholder="请输入性别">
        <input type="button" value="提交" id="bn_add">
    </div>    

    <div class="div_2">
        <table>
            <caption>学生信息表</caption>
            <tr>
                <th>编号</th>
                <th>姓名</th>
                <th>性别</th>
                <th>操作</th>
            </tr>

            <tr>
                <td>1</td>
                <td>张三</td>
                <td></td>
                <td><a href="javascript:void(0);" onclick="delTr(this);" >删除</a></td>
            </tr>
        </table>
    </div>

    <script>
        function delTr(obj) {
                let table = obj.parentNode.parentNode.parentNode;
                let tr = obj.parentNode.parentNode;
                table.removeChild(tr);
        }

        let add = document.getElementById("bn_add");
        add.onclick = function() {
            //添加id
            let id_text = document.getElementById("id").value;
            let lie1 = document.createElement("td");
            let text1 = document.createTextNode(id_text);
            lie1.appendChild(text1);
            //添加姓名
            let name_text = document.getElementById("name").value;
            let lie2 = document.createElement("td");
            let text2 = document.createTextNode(name_text);
            lie2.appendChild(text2);
            //添加年龄
            let sex_text = document.getElementById("sex").value;
            let lie3 = document.createElement("td");
            let text3 = document.createTextNode(sex_text);
            lie3.appendChild(text3);
             //添加操作
            let lie4 = document.createElement("td");
            let a = document.createElement("a");
            a.setAttribute("href", "javascript:void(0);");
            a.setAttribute("onclick", "delTr(this);");
            let text4 = document.createTextNode("删除");
            a.appendChild(text4);
            lie4.appendChild(a);

            let row = document.createElement("tr");
            row.appendChild(lie1);
            row.appendChild(lie2);
            row.appendChild(lie3);
            row.appendChild(lie4);

            //6.获取table
            var table = document.getElementsByTagName("table")[0];
            table.appendChild(row);
        }
    </script>
</body>
</html>
3.HTML DOM对象
  • 简介

HTML DOM是一种编程接口,它表示网页文档的结构化模型。它将整个网页作为一个树形结构表示,其中每个元素(如标签、属性、文本等)都是树的一个节点。HTML DOM 提供了一组对象,这些对象允许开发者通过脚本语言来操作网页的各个部分。例如,可以通过HTML DOM来获取元素、改变元素的内容、修改元素的样式、添加或删除元素等操作。这使得开发者能够创建动态、交互式的网页应用程序。

  • 标签体的设置和获取:innerHTML
//获取table标签的内容
let content = table.innerHTML
//动态表格改进方案
<script>
        function delTr(obj) {
                let table = obj.parentNode.parentNode.parentNode;
                let tr = obj.parentNode.parentNode;
                table.removeChild(tr);
        }

        let add = document.getElementById("bn_add");
        add.onclick = function() {
            //添加id
            let id_text = document.getElementById("id").value;
            //添加姓名
            let name_text = document.getElementById("name").value;
            //添加年龄
            let sex_text = document.getElementById("sex").value;
            
            let table = document.getElementsByTagName("table")[0];
            table.innerHTML += "<td>" + id_text + "</td>" + "<td>" + name_text + "</td>"
            + "<td>" + sex_text + "</td>" + "<td><a href='javascript:void(0);' οnclick='delTr(this);'>删除</a></td>";
        }
</script>
  • 使用html元素对象的属性

HTML DOM对象有很多,这里不展开叙述,可以W3C学习,这里只了解一下Form对象

Form对象

  • Form对象的引用
表单的引用方法1:通过i数组来访问
document.forms[0]

表单的引用方法2:通过id值来访问
document.forms[“MyForm”]
document.MyForm

表单的引用方法3:用document对象的getElementById方法来访问
document.getElementById(“MyForm”)
  • Form表单的属性与方法

image-20231230205024694

  • 控制元素样式
<body>
    <div class="div1">
        你好
    </div>

<style>
    .d1 {
        color: red;
    }
</style>

<script>
    //方法一:通过document获取元素对象,调用其style属性进行修改样式
    let div1 = document.getElementsByClassName("div1")[0];
    div1.style.border = "3px solid";
    div1.style.fontSize = "50px";

    //方法二:提前定义好类选择器的样式,通过元素的className属性来设置其class属性值
    div1.className = "d1";
</script>

</body>
4.事件机制

**事件机制:**某些组件被执行了某些操作后,触发某些代码的执行

事件机制分为

事件:某些操作。如: 单击,双击

事件源:事件源:组件。如: 按钮 文本输入框…

事件处理程序(监听器):代码

事件处理的过程:触发事件,启动事件处理程序,事件处理程序做出反映

  • 事件分类

鼠标,键盘事件

image-20240719105812688

//鼠标和键盘事件常常会监听获取哪个键被点击
* 定义方法时,定义一个形参,接受event对象。
* event对象的button属性可以获取哪个鼠标按钮键被点击了
* event对象的keyCode属性可以获取哪个键盘按钮键被点击了
document.getElementById("username").onmousedown = function(event){// alert("鼠标点击了....");
alert(event.button);}

document.getElementById("username").onkeydown = function(event){// alert("鼠标点击了....");
	if(event.keyCode == 13){alert("提交表单");}
}

表单事件

image-20231230200705193

//onblur失去焦点:常常被用作表单的校验
//onsubmit事件会对提交进行阻拦,如果函数返回值未true放行,如果为false进行阻拦
document.getElementById("form").onsubmit = function(){
    var flag = false;
    return flag;
}

窗口事件

image-20231230200726025

//onload用法
一般js代码放在最后,防止因为访问未定义的标签或元素报错
onload事件是在文档完全加载完成触发事件,这样可有效解决上述问题

语法:window.onload = function() {
    //执行的js代码
}
  • 绑定事件
  1. 使用addEventListener方法:

    javascriptCopy Codeconst element = document.getElementById('myElement'); // 获取要绑定事件的元素
    element.addEventListener('click', function() {
        // 处理点击事件的代码
    });
    

    这种方式可以为元素添加多个不同类型的事件监听器,例如clickmouseoverkeydown等。

  2. 直接赋值事件处理程序:

    javascriptCopy Codeconst element = document.getElementById('myElement');
    element.onclick = function() {
        // 处理点击事件的代码
    };
    

    这种方式比较旧式,但仍然有效。但是,它只能为每种事件类型设置一个处理程序,并且不支持添加多个处理程序。

  3. 使用HTML属性(不推荐):

    htmlCopy Code<button id="myButton" onclick="handleClick()">Click me</button>
    
    javascriptCopy Codefunction handleClick() {
        // 处理点击事件的代码
    }
    

    这种方式将事件处理程序直接嵌入到HTML中,不推荐使用,因为它将结构(HTML)和行为(JavaScript)混合在一起,不利于维护和扩展。

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

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

相关文章

近几天,北京大学副校长、教务长王博亲自为藏族女孩送上北京大学首封录取通知书!

藏族女孩代吉永措收到了北京大学2024年首封本科录取通知书。她来自青海湟川中学&#xff0c;已被北京大学历史学科强基计划录取&#xff0c;即将就读于北京大学历史学系。北京大学副校长、教务长王博亲自为代吉永措送上了这份录取通知书&#xff0c;并与她亲切交流了未来的学习…

Linux介绍和文件管理

一Linux的起源 1.Unix Dennis Ritchie和Ken Thompson发明了C语言&#xff0c;而后写出了Unix的内核 2.Minix MINIX是一种基于微 内核架构的类UNIX计算机操作系统&#xff0c;由 Andrew S. Tanenbaum发明 3.Linux内核 芬兰赫尔辛基大学的研究生Linus Torvalds基于Gcc、 ba…

注册安全分析报告:OneApm

前言 由于网站注册入口容易被黑客攻击&#xff0c;存在如下安全问题&#xff1a; 暴力破解密码&#xff0c;造成用户信息泄露短信盗刷的安全问题&#xff0c;影响业务及导致用户投诉带来经济损失&#xff0c;尤其是后付费客户&#xff0c;风险巨大&#xff0c;造成亏损无底洞 …

C语言 ——— 打印水仙花数

目录 何为水仙花数 题目要求 代码实现 何为水仙花数 “水仙花数”是指一个n位数&#xff0c;其各位数字的n次方之和等于该数本身 如&#xff1a;153 1^3 5^3 3^3&#xff0c;则153就是一个“水仙花数” 题目要求 求出0~100000的所有“水仙花数”并输出 代码实现 #i…

万字 AI 干货及感悟分享

最近一直在研究 AI Agent 在零代码平台中的应用, 特地研究并总结了一份AI学习的干货, 方便大家快速理解LLM, 并熟悉主流的AI大模型框架, 以及如何基于AI, 来改善我们传统的工作模式. 上面是本文的核心大纲, 接下来开始我的分享和总结. LLM介绍 1. LLM概念 大语言模型&#x…

【安当产品应用案例100集】001 — 基于UKEY的文件加密流转

随着企业信息化程度的不断提高&#xff0c;数据已成为企业最重要的资产之一。然而&#xff0c;数据泄露的风险也随之增加。数据泄露可能导致企业商业机密泄露、客户隐私泄露、经济损失以及法律诉讼等一系列严重后果。因此&#xff0c;保护数据安全已成为企业不可忽视的重要任务…

互联网行业的产品方向(二)

数字与策略产品 大数据时代&#xff0c;数据的价值越来越重要。大多数公司开始对内外全部数据进行管理与挖掘&#xff0c;将业务数据化&#xff0c;数据资产化&#xff0c;资产业务化&#xff0c;将数据产品赋能业务&#xff0c;通过数据驱动公司业务发展&#xff0c;支撑公司战…

3112. 访问消失节点的最少时间 Medium

给你一个二维数组 edges 表示一个 n 个点的无向图&#xff0c;其中 edges[i] [ui, vi, lengthi] 表示节点 ui 和节点 vi 之间有一条需要 lengthi 单位时间通过的无向边。 同时给你一个数组 disappear &#xff0c;其中 disappear[i] 表示节点 i 从图中消失的时间点&#xff0…

Linux-交换空间(Swap)管理

引入概念 在计算机中&#xff0c;硬盘的容量一般比内存大&#xff0c;内存&#xff08;4GB 8GB 16GB 32GB 64GB…&#xff09;&#xff0c;硬盘&#xff08;512GB 1T 2T…&#xff09;。 冯诺依曼的现代计算机结构体系里面的存储器就是内存 内存是一种易失性存储器&#xff0c…

如何在 PostgreSQL 中处理海量数据的存储和检索?

&#x1f345;关注博主&#x1f397;️ 带你畅游技术世界&#xff0c;不错过每一次成长机会&#xff01;&#x1f4da;领书&#xff1a;PostgreSQL 入门到精通.pdf 文章目录 如何在 PostgreSQL 中处理海量数据的存储和检索&#xff1f;一、优化表结构设计二、分区技术三、数据压…

二叉树的后序遍历(寻找重复的子树,序列化

class Solution {List<TreeNode> resnew LinkedList<>();Map<String,Integer> mapnew HashMap<>();//用于存储子树public List<TreeNode> findDuplicateSubtrees(TreeNode root) {String xfind(root);return res;}public String find(TreeNode r…

HZNUCTF2023中web相关题目

[HZNUCTF 2023 preliminary]guessguessguess 这道题目打不开了 [HZNUCTF 2023 preliminary]flask 这道题目考察SSTI倒序的模板注入&#xff0c;以及用env命令获得flag 看题目&#xff0c;猜测是SSTI模板注入&#xff0c;先输入{7*7},发现模板是倒序输入的 输入}}7*7{{返回77…

springboot nacos的各种注解、手动操作监听配置变化(监听指定DataId/监听任何变化)

文章目录 springboot nacos监听配置变化&#xff08;监听指定DataId/监听任何变化&#xff09;监听任何配置变化Nacos注解NacosConfigurationPropertiesNacosValueNacosConfigListenerNacosInjectedNacosConfigServiceNacosNamingService springboot nacos监听配置变化&#xf…

OpenAI 开打价格战,GPT-4o 最新变种价格骤降 96%-97%

当地时间周四早晨&#xff0c;美国人工智能初创公司 OpenAI 宣布&#xff0c;正式上架价格显著下降的新一代入门级别人工智能「小模型」GPT-4o mini。 价格比较&#xff5c;图片来源&#xff1a;Artificial Analysis 据 OpenAI 披露&#xff0c;GPT-4o mini 的 API 价格将会是…

【AI大模型Agent探索】深入探索实践 Qwen-Agent 的 Function Calling

系列篇章&#x1f4a5; No.文章1【Qwen部署实战】探索Qwen-7B-Chat&#xff1a;阿里云大型语言模型的对话实践2【Qwen2部署实战】Qwen2初体验&#xff1a;用Transformers打造智能聊天机器人3【Qwen2部署实战】探索Qwen2-7B&#xff1a;通过FastApi框架实现API的部署与调用4【Q…

django报错(二):NotSupportedError:MySQL 8 or later is required (found 5.7.43)

执行python manage.py runserver命令时报版本不支持错误&#xff0c;显示“MySQL 8 or later is required (found 5.7.43)”。如图&#xff1a; 即要MySQL 8或更高版本。但是企业大所数用的还是mysql5.7相关版本。因为5.7之后的8.x版本是付费版本&#xff0c;贸然更新数据库肯定…

JAVASE-医疗管理系统项目总结

文章目录 项目功能架构运行截图数据库设计设计模式应用单列设计模式JDBC模板模板设计模式策略模式工厂设计模式事务控制代理模式注解开发优化工厂模式 页面跳转ThreadLocal分页查询实现统计模块聊天 项目功能架构 传统的MVC架构&#xff0c;JavaFX桌面端项目&#xff0c;前端用…

水经微图Web版1.10.0发布

水经微图&#xff08;简称“微图”&#xff09;新版已上线&#xff0c;在该版本中主要新增了三调图例符号库&#xff0c;以及其它功能的优化。 当前版本 当前版本号为&#xff1a;1.10.0-beta.2 如果你发现该版本中存在问题&#xff0c;请及时反馈给我们修订。 关于我们产品…

Adobe国际认证详解-影视后期

在当今的数字媒体时代&#xff0c;影视后期制作作为创意产业的核心环节&#xff0c;对于专业技能的要求日益提高。Adobe国际认证&#xff0c;作为全球创意设计领域的重要标杆&#xff0c;为影视后期制作人员提供了一个展示自我、提升技能的国际舞台。 何为影视后期&#xff1f;…

javaEE (3)

Json json--JavaScript object notation (js对象表现形式) 在后端将java对象转为json格式的字符串 有很多第三方组件,可以直接将java对象转为json格式的字符串 new objectMapper().writeValueAsString(); 返回string类型 <!-- jackson--><dependency>&…