Web APIs简介 Dom

news2025/1/14 1:18:26

JS的组成

 API

API 是一些预先定义的函数,目的是提供应用程序与开发人员基于软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节

简单理解:API是给程序员提供的一种工具,以便能更轻松的实现想要完成的功能。

 

 DOM简介

1.1什么是DOM

文档对象模型,是W3C组织推荐的处理可扩展标记语言的标准编程接口。

W3C已经定义了一系列的DOM接口,通过这些DOM接口可以改变网页的的内容、结构和样式

 获取元素

如何获取页面元素

DOM在我们万宁实际开发中主要用来操作元素

获取页面中的元素可以使用以下几种方式:

  • 根据id获取
  • 根据标签名获取
  • 通过HTML5新增的方法获取
  • 特殊元素获取
根据ID获取

使用getElementById()方法可以获取带有ID的元素对象

document.getElementById('Id');

使用console.dir()可以打印我们获取的元素对象,更好的查看对象里面的属性和方法。 

根据标签名获取

使用getElementByTagName()方法可以返回带有指定标签名的对象集合。

document.getElementByTagName('标签名');

注意:

  1. 因为得到的是一个对象的集合,所以我们想要操作里面的元素就需要遍历
  2. 得到元素对象是动态的
  3. 如果获取不到元素,则返回为空的伪数组(因为获取不到对象)
通过HTML5新增的方法获取

1.document.getElementByClassName('类名');//根据类名返回元素对象集合 

 2.document.querySelector('选择器');//根据选择器返回第一个元素对象

3.document.querySelectorAll('选择器');//根据指定选择器返回 

注意:

querySelect和querySelectorAll里面的选择器需要加符号,比如document,querySelector('#nav'); 

 获取特殊元素(body,html)

获取body元素

1.document.body//返回body元素对象

获取html元素

1.document.documentElement//返回html元素对象 

 事件基础

事件概述

JavaScript使我们有能力创建动态页面,而事件是可以被JavaScript侦测到的行为

网页中的每个元素都可以产生某些可触发JavaScript的事件

事件三要素

  1. 事件源
  2. 事件类型
  3. 事件处理程序

执行事件的步骤

  1. 获取事件源
  2. 注册事件
  3. 添加事件处理程序(采取函数赋值形式) 

常见的鼠标事件

操作元素

JavaScript的DOM操作可以改变网页内容、结构和样式,我们可以利用DOM操作元素来改变元素里面的内容、属性等

改变元素内容

element.innerText

从起始位置到终止位置的内容,但它去除html标签,同时也会去掉空格和换行

element.innerHTML 

起始位置到终止位置的全部内容,包括html标签,同时保留空格和换行 

常用元素的属性操作

1.innerText、innerHTML改变元素内容

2.src、href

3.id、alt、title 

表单元素的操作属性

利用DOM可以操作如下表单元素的属性:

type,value,checked,selected,disabled 

 样式属性操作

我们可以通过JS修改元素的大小、颜色、位置等样式

1.element.style  行内样式操作

2.element.calssName  类名样式操作

注意:

1.JS里面的样式采取驼峰命名法

2.JS修改style样式操作,产生的是行内样式,css权重比较高 

3.className会直接更改元素的类名,会覆盖原先的类名

排他思想

如果有一组元素,我们想要一个元素实现某种样式,需要用到循环的排他思想算法:

  1. 所有元素全部清除样式
  2. 给当前元素设置样式
  3. 注意顺序不能颠倒 

eg.百度换肤

 

 自定义属性的操作

1.获取属性值

  • element.属性   获取属性值
  • element.getAttribute('属性')

区别

  • element.属性  获取内置属性值(元素本身自带属性)
  • element.getAttribute('属性');主要获得自定义的属性(标准)我们程序员自定义属性 

2.设置属性值

  • element 属性='值'    设置内置属性值
  • element.setAttribute('属性','值'); 

区别

  • element.属性   设置内置属性值
  • element.setAttribute('属性');主要设置自定义的属性 

 3.移除属性

 element.removeAttribute('属性');

H5自定义属性

自定义属性目的是为了保存并使用数据 。有些数据可以保存到页面中而不用保存到数据库中。

自定义属性获取是通过getAttribute('属性')获取

但是有些自定义属性很容易引起歧义,不容易判断是元素的内置属性还是自定义属性

h5给我们新增了自定义属性:

1.设置H5自定义属性

H5规定自定义属性data-开头作为属性名并且赋值

 2.获取H5自定义属性

  1. 兼容性获取    element.getAttribute('data-index');
  2. H5新增element.dataset.index 或者element.dataset['index'] ie11才开始支持

节点操作 

 

 节点概述

网页中的所有内容都是节点(标签、属性、文本、注释等)、在DOM中,节点使用node来表示

HTML  DOM 树中的所有结点均可通过JavaScript进行访问,所有HTML元素(节点)均可倍修改,也可以创建或删除

 节点概述

一般地,节点至少拥有 node Type(节点类型)、nodeName(节点名称) 和nodeValue(节点值)这三个基本属性

  • 元素节点 node Type为1
  • 属性节点 node Type为2
  • 文本节点 node Type为3(包含文字、空格、换行等)

我们在实际开发中,节点操作主要操作的是元素节点

节点层级

利用DOM树可以把节点划分为不同的层级关系,常见的是父子兄层级关系

 1.父级节点

node.parentNode

  • parentNode属性可返回某节点的父节点,注意的是最近的一个父节点
  • 如果指定的节点没有父节点则返回null 

子节点

1.parentNode.childNodes(标准) 

parentNode.childNodes返回包含指定节点的子节点的集合 ,该集合为即时更新的集合

注意:返回值里面包含了所有的子节点,包括元素节点,文本节点等

如果只想要获得里面的元素节点,则需要专门处理。所以我们一般不提倡使用childNodes

2.parentNode.children(非标准)

parentNode.child是一个只读属性,返回所有子元素节点。他返回子元素节点,其余节点不返回(这个是我们重点掌握的)

虽然children是一个非标准,但是得到了各个浏览器的支持,因此我们可以放心使用 

3.parentNode.firstChild 

 firstChild 返回第一个子节点,找不到则返回null,同样,也是包含所有的节点。

4.parentNode.lastChild

 lastChild返回最后一个子节点,找不到则返回null。同样,也是包含所有的节点

5.parentNode.firstElementChild

 firstElementChild返回第一个子元素节点,找不到则返回null

6.parentNode.lastElementChild

 lastElementChild返回最后一个子节点,找不到则返回null

注意:5.6方法有兼容性问题,IE9以上才支持

 

兄弟节点

1.node.nextSibling 

nextSlibing返回当前元素的下一个兄弟节点,找不到则返回null。同样,也是包含所有的节点。

2.node.previousSling 

previousSling返回当前元素上一个兄弟节点,找不到则返回null,同样,也是包含所有的节点。

3.node.nextElementSbling

nextElementSibling返回当前元素下一个兄弟节点,找不到则返回null。

4.node.previousElementSibling 

previousElementSibling 返回当前元素上一个兄弟节点, 找不到则返回null。

注意:这两个方法都有兼容性问题,IE9以上才支持。

如何解决兼容性问题?

自己封装一个兼容性函数

function getNextElementSibling(element) {
    var el=element;
    while (el=el.nextSibling) {
        if (el.nodeType===1) {
            return el;
        }
       }
        return null;
    }

创建节点

document,createElement('tagName')

 document,createElement() 方法创建由tagName指定的HTML元素。因为这些元素原先不存在,是根据我们的需求动态生成的,所以我们也称为动态创建元素节点

添加节点

1.node.appendChild(child)

 node.appendChild(child)方法将一个节点添加到指定父节点的子节点列表末尾。类似于CSS里面的after伪元素。

2.node.insertBefore(child,指定元素)

 node.insertBefore()方法将一个节点添加到父节点的指定节点前面。类似于CSS里面的before伪元素。

删除节点

node.removeChild(child)

node.removeChild方法从DOM中删除一个子节点,返回删除的节点。 

复制节点(克隆节点)

node.cloneNode()

node.cloneNode()方法返回调用该方法的节点的一个副本。也称为克隆节点/拷贝节点

注意:

1.如果括号参数为空或者为false,则是浅拷贝,即只克隆复制节点本身,不克隆里面的子节点。

2.如果括号参数为true,则是深度拷贝,会复制节点本身以及里面所有的子节点。

 

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1.0">
    <title>Document</title>
    <style>
        table {
            width: 50px;
            margin: 100px auto;
            border-collapse: collapse;
            text-align: center;
        }
        td,
        th {
            border: 1px solid #333;
        }
        thead tr {
            height: 40px;
            background-color: #ccc;
        }
    </style>
    </head>
<body>
    <table cellspacing="0">
        <thead>
            <tr>
                <th>姓名</th>
                <th>科目</th>
                <th>成绩</th>
                <th>操作</th>
            </tr>
        </thead>
        <tbody>
    
        </tbody>
    </table>
    <script>
        //先准备好学生数据
        var datas=[{
            name:'ali',
            subject:'math',
            score:100
        },{
            name:'niki',
            subject:'math',
            score:98
        },{
            name:'lili',
            subject:'math',
            score:98
        }];
        //往tbody里面建行,有几个人(通过数组长度)我们就建几行
        var tbody=document.querySelector('tbody');
        for(var i=0; i<datas.length;i++){
            var tr=document.createElement('tr');
            tbody.appendChild(tr);
    
            for(var k in datas[i]){
                var td=document.createElement('td');
                td.innerHTML=datas[i][k];
                tr.appendChild(td);
            }
            var td=document.createElement('td');
            td.innerHTML='<a href="javascript:;">删除</a>';
            tr.appendChild(td);
        }
    
            var as=document.querySelectorAll('a');
            for (var i=0;i<as.length;i++){
                as[i].onclick=function() {
                    tbody.removeChild(this.parentNode.parentNode)
                }
            }
        
        </script>
    </body>
    </html>

 三种动态创建元素区别
  • document.write()
  • element.innerHTML
  • document.createElement()

区别

  1. document.write 是直接将内容写入页面的内容流,但是文档流执行完毕,则它会导致页面全部重绘
     1. document.write() //创建元素  如果页面文档流加载完毕,再调用这句话会导致页面重绘
           var btn = document.querySelector('button');
           btn.onclick = function() {
             document.write('<div>123</div>');
           }

  2.  innerHTML是将内容写入某个DOM节点,不会导致页面全部重绘
     // 2. innerHTML 创建元素
            var inner = document.querySelector('.inner');
            // for (var i = 0; i <= 100; i++) {
            //     inner.innerHTML += '<a href="#">百度</a>'
            // }
            var arr = [];
            for (var i = 0; i <= 100; i++) {
                arr.push('<a href="#">百度</a>');
            }
            inner.innerHTML = arr.join('');

  3. innerHTML创建多个元素效率更高(不要拼接字母,采取数组形式拼接),结构稍微复杂

  4. createElement()创建多个元素效率稍微低一点,但是结构更清晰
     // 3. document.createElement() 创建元素
            var create = document.querySelector('.create');
            for (var i = 0; i <= 100; i++) {
                var a = document.createElement('a');
                create.appendChild(a);
            }

总结:不同浏览器下,innerHTML效率要比createElement高

文档对象模型(DOM)是W3C组织推荐的处理可扩展标记语言的标准编程接口

W3C已经定义了一系列的DOM接口,通过这些DOM接口可以改变网页的内容、结构和样式。

  1. 对于Javascript。为了能够使Javascript操作HTML,Javascript就有了一套自己的dom编程接口。
  2. 对于HTML,dom使得html形成一颗dom树,包含文档、元素、节点

 创建

  1. document.write
  2. innerHTML
  3. createElement

  1. appendChild
  2. innerHTML

 删

  1. removeChild

 改

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

  1. 修改元素属性:src\href\title等
  2. 修改普通元素属性:innnerHTML\innerText
  3. 修改表单元素:value\type\disabled
  4. 修改元素样式: style\className

主要获取查询dom的元素

  1. DOM提供的API方法: getelementById\getElementByTagNmae
  2. H5提供的新方法:querySelector\querySelectorAll
  3. 利用节点操作获取元素:parentNode\children\previousElementSibling\nextElementSibling 

属性操作

主要针对于自定义属性

  1. setAttribute:设置dom的属性值
  2. getAttribute:得到dom的属性值
  3. removeAttribute移除属性 

 

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

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

相关文章

[计算机知识] 各种小问题思考

哈希算法以及哈希冲突 哈希算法&#xff1a;将任何长度的输入通过散列函数转换成固定长度的字符串 哈希冲突&#xff1a;不同的输入经过哈希函数处理后得到相同的哈希值 因为哈希函数的输出域是有限的 解决哈希冲突&#xff1a; 1. 开放寻址&#xff1a;产生哈希冲突后&…

刷题之Leetcode704题(超级详细)

704. 二分查找 力扣题目链接(opens new window)https://leetcode.cn/problems/binary-search/ 给定一个 n 个元素有序的&#xff08;升序&#xff09;整型数组 nums 和一个目标值 target &#xff0c;写一个函数搜索 nums 中的 target&#xff0c;如果目标值存在返回下标&am…

【Apache Doris】周FAQ集锦:第 1 期

【Apache Doris】周FAQ集锦&#xff1a;第 1 期 SQL问题数据操作问题运维常见问题其它问题关于社区 欢迎查阅本周的 Apache Doris 社区 FAQ 栏目&#xff01; 在这个栏目中&#xff0c;每周将筛选社区反馈的热门问题和话题&#xff0c;重点回答并进行深入探讨。旨在为广大用户和…

【Java设计模式】序:设计模式总体概述

目录 什么是设计模式设计模式的分类1 创建型模式1.1. 单例&#xff08;Singleton&#xff09;1.2 原型&#xff08;Prototype&#xff09;1.3 工厂方法&#xff08;FactoryMethod&#xff09;1.4 抽象工厂&#xff08;AbstractFactory&#xff09;1.5 建造者&#xff08;Builde…

<网络安全>《71 微课堂<常见的国家级APT组织介绍>》

1 简介 国家级APT&#xff08;Advanced Persistent Threat&#xff0c;高级持续性威胁&#xff09;组织是有国家背景支持的顶尖黑客团伙&#xff0c;专注于针对特定目标进行长期的持续性网络攻击。 2 十大APT 2.1 NSA 美国国家安全局&#xff08;National Security Agency&a…

Redis面试题28道

1、什么是类加载器&#xff0c;类加载器有哪些&#xff1f; 1、什么是类加载器&#xff1f; 类加载器负责加载所有的类&#xff0c;其为所有被载入内存的类生成一个 java.lang.Class 实例对象。 2、类加载器有哪些&#xff1f; JVM 有三种类加载器&#xff1a; &#xff08…

基于GaN的半导体光学放大器SOA

摘要 基于GaN的材料可覆盖很宽的光谱范围&#xff0c;以紫外、紫、蓝、绿和红波发射的激光二极管已经商业化。基于GaN的半导体光学放大器&#xff08;SOA&#xff09;具有提高激光二极管输出功率的能力&#xff0c;因此SOA将有很多潜在应用。未来需要利用短波、超快脉冲特性的…

GD32F470_ADS1115 超小型 16位 模数转换器 ADC 4通道模块移植

2.9 ADS1115多路模数转换器 ADS1115 器件是兼容 IIC 的 16 位高精度低功耗模数转换器 (ADC)&#xff0c;采用超小型无引线 X2QFN-10 封装和 VSSOP-10 封装。ADS111x 器件采用了低漂移电压基准和振荡器。ADS1114 和 ADS1115 还采用可编程增益放大器(PGA)和数字比较器。这些特性加…

kali报错Unable to connect to remote host: No route to host,如何解决??

&#x1f3c6;本文收录于「Bug调优」专栏&#xff0c;主要记录项目实战过程中的Bug之前因后果及提供真实有效的解决方案&#xff0c;希望能够助你一臂之力&#xff0c;帮你早日登顶实现财富自由&#x1f680;&#xff1b;同时&#xff0c;欢迎大家关注&&收藏&&…

《搜广推算法指南》(2024版) 重磅发布!

节前&#xff0c;我们星球组织了一场算法岗技术&面试讨论会&#xff0c;邀请了一些互联网大厂朋友、参加社招和校招面试的同学&#xff0c;针对算法岗技术趋势、大模型落地项目经验分享、新手如何入门算法岗、该如何准备、面试常考点分享等热门话题进行了深入的讨论。 结合…

全自动封箱机的工作原理:科技与效率的完美结合

随着科技的不断发展&#xff0c;越来越多的自动化设备走进了我们的日常生活和工业生产中。其中&#xff0c;全自动封箱机作为物流包装领域的重要一环&#xff0c;凭借其高效、精准的工作性能&#xff0c;正逐渐成为提升生产效率、降低劳动成本的得力助手。星派就来与大家深入探…

python调用java中的jar

一、基于IDEA生成可执行jar包 1、编写class的代码&#xff0c;注意一定要有main()方法才可以生成jar包&#xff0c;main()方法可以没有内容。例如下Java 代码&#xff1a; package Project;public class Demo {public static void main(String[] args){Demo t2 new Demo();S…

HarmonyOS(鸿蒙)——单击事件

2.4 实现ClickedListener接口并重写onClick方法 2.5 实现onClick方法中的具体逻辑&#xff0c;以此完成点击事件的相关业务操作 三、测试 3.1 登录远程模拟器 3.2 运行项目 四、精选好文 一、简介 1.1 什么是组件 组件就是文本、按钮、图片等元素的统称 1.2 什么是事件 …

NKCTF2024 re VM?VM!WP

逻辑似乎很简单&#xff08;个鬼啊&#xff09; 这个函数是把输入的字符转化为二进制并倒序存储 sub_1570太大了加载不出来&#xff0c;应该是加密的主逻辑&#xff0c;目的是需要输出1 可以通过删除栈的方法强行转化伪代码 首先删掉这部分 9A0改小点 这个也是 栈这里U一下再…

docker部署在线流程图

下载镜像 docker pull registry.cn-beijing.aliyuncs.com/wuxingge123/drawio:latestdocker-compose部署 vim docker-compose.yml version: 3 services:drawio:container_name: drawioimage: registry.cn-beijing.aliyuncs.com/wuxingge123/drawio:latestports:- 8083:8080v…

【MATLAB源码-第25期】基于matlab的8QAM调制解调仿真,手动实现未调用内置函数,星座图展示。

操作环境&#xff1a; MATLAB 2022a 1、算法描述 8QAM调制&#xff08;8 Quadrature Amplitude Modulation&#xff09;是一种数字调制技术&#xff0c;它可以在有限带宽内传输更多的信息比特。在8QAM调制中&#xff0c;每个符号可以携带3个比特的信息。QAM调制是将数字信号…

【数据分析面试】6.计算对话总数(SQL)

题目&#xff1a;计算对话总数 给定了名为 messenger_sends 的消息发送表格&#xff0c;找出总共有多少个唯一的对话。 注&#xff1a;在某些记录中&#xff0c;receiver_id 和 sender_id 从初始消息中互换了。这些记录应视为同一个对话。 示例&#xff1a; 输入&#xff1…

ubuntu更换国内镜像源,下载增速

方法一&#xff1a;通过脚本更换源 1.备份原来的源 sudo cp /etc/apt/sources.list /etc/apt/sources_init.list 将原来的源保留一下&#xff0c;以后想用还可以继续用 2.更换源 sudo gedit /etc/apt/sources.list 使用gedit打开文档&#xff0c;将下面的阿里源复制进去&am…

微信小程序纯CSS实现好看的加载动画

进入下面小程序可以体验效果&#xff1a; WXML: <wxs module"img" src"./loading.wxs"></wxs> <view class"loading-container {{show?:loading-container-hide}}"><view class"loading-mask" wx:if"{{ma…

分享:搭建企微知识库简单易学步骤

说起企微知识库&#xff0c;可能有些人还不太清楚&#xff0c;为什么现在很懂企业选择搭建企微知识库&#xff1f;其实&#xff0c;企微知识库就是一个装满了企业的各种知识、经验和资料的载体。目的是为了方便员工随时查找和学习、有助于知识的传承和共享、加强团队协作和沟通…