DOM简介


DOM是W3C(World Wide Web Consortium)标准。

“W3C 文档对象模型(DOM,全称Document Object Model)”是一个使程序和脚本有能力动态地访问和更新文档的内容、结构以及样式的平台和语言中立的接口。

DOM被分为3个不同的部分/级别:

  • 核心 DOM
  • XML DOM
  • HTML DOM

核心DOM:提供了操作文档的公有属性和方法,就相当于鼻祖。它可以可操作一切结构化文档的API,包括HTML和XML。是万能的!但是很繁琐!

HTML DOM:它是专门操作HTML文档的简化版DOMAPI仅对常用的复杂的API进行了简化,对核心DOM进行了在HTML方面的拓展。不是万能的!但是简单

XML DOM:提供了所有XML元素的对象和属性,以及访问方法,与HTML DOM类似。

HTML DOM


节点概念

HTML DOM 把所有的元素全部转化为节点对象,以后要想操作HTML里的内容就等于操作节点。

节点分类

  • 文档节点[object HTMLDocument]
  • 元素节点[object HTMLXXXElement]
  • 属性节点[object Attr]
  • 内容节点[object Text]

1、文档节点就是根,只存在一个,想要得到它十分容易,写一个 document 相当于文档节点了。

<script>
document.write(document);
</script>
渲染结果

2、元素节点:文档节点是根,所以他肯定有许多小弟了,比如 div 、p等等,都是元素节点,属于文档节点的下级。

3、属性和内容节点:id就是div的一个属性节点的节点名,“HTML DOM”就是div内容节点的节点值,节点名和节点值就是节点的属性之一。

<div id="div1">HTML DOM</div>

DOM查找


获取元素节点

我们对DOM操作,最重要的是想修改它的内容,而想要修改DOM元素,我们必须先找到他

  • document.getElementById       通过id获取元素节点 
  • getElementsByTagName       通过标签名称获取元素节点
  • getElementsByClassName         通过类名获取元素节点
  • getElementsByName                  通过表单元素的name获取元素节点
  • querySelector("[selector]")     支持一切css中的选择器,但如果匹配多个,只会返回第一个
  • querySelectorAll("[selector]")    返回所有选中的元素

因为id是唯一的,所以上面除了通过id获取元素节点外,其他获取到的都是节点数组。

例如:

<!--id获取到是单个元素-->
<div id="div1" >
HTML DOM
</div> <script>
var div1 = document.getElementById("div1");
//或者
div1 = document.querySelector("#div1");
document.write(div1);
</script>
渲染结果

<!--其他获取到的是元素数组-->
<div id="div1" >
HTML DOM
</div> <script>
var divs = document.getElementsByTagName("div");
var div1 = divs[0];
</script>
渲染结果

遍历元素数组,根据javascript的知识,数组有个属性length,因此我们可以使用for循环遍历他

<div class="div">
HTML DOM
</div>
<div class="div">
DIV2
</div> <script> console.log("--getElementsByTagName--");
var element = document.getElementsByTagName("div");
for(var i = 0; i < element.length; i++){
console.log(element[i].innerText);
}  console.log("--querySelectorAll--");
element = document.querySelectorAll("div");
for(var i = 0; i < element.length; i++){
console.log(element[i].innerText);
} console.log("--querySelectorAll select class--");
element = document.querySelectorAll(".div");
for(var i = 0; i < element.length; i++){
console.log(element[i].innerText);
}  
</script>

获取属性节点

首先需要获取到元素节点,然后可以通过attributes获取元素节点的属性节点,属性可以有多个,所以获取到是属性节点数组。

若要获取某一指定的属性的节点例如id,可以通过键名xx["id"]获取到属性节点。

<div id="d1" align="center" class="abc">hello HTML DOM</div>
<script>
var div1 = document.getElementById("d1");
var as = div1.attributes;
document.write("div总共有"+as.length +" 个属性");
document.write("分别是:");
for(i = 0; i< as.length; i++){
document.write("<br>");
document.write(as[i].nodeName);
document.write(":");
document.write(as[i].nodeValue);
}
document.write("<br>");
document.write("div的id属性值是:"+ as["id"].nodeValue);
</script>

渲染结果

获取内容节点

通过childNodes获取到的第一个子节点就是内容节点

<div id="d1" align="center" class="abc">hello HTML DOM</div>
<script>
var div1 = document.getElementById("d1");
var content = div1.childNodes[0];
document.write("div的内容节点名是:"+content.nodeName);
document.write("<br>");
document.write("div的内容节点值是:"+content.nodeValue);
</script>

渲染结果

节点的属性


  • nodeName    节点名称
  • nodeValue     节点值
  • nodeType      节点类型
  • innerHTML    元素节点的文本信息
  • 元素节点的属性,可直接访问
    • id  
    • value  
    • className  
<div id="div1" class="d">
愿用一生守护你
</div>
<hr>
<script>
function w(s){
document.write(s);
} //元素节点
var div1 = document.getElementById("div1");
//属性节点数组
var attrs = div1.attributes;
//遍历属性节点
for(var i = 0; i < attrs.length; i++){
//节点名
w(attrs[i].nodeName);
w(" : ");
//节点值
w(attrs[i].nodeValue);
w("<br>");
} //获取内容节点的节点值
var value = div1.childNodes[0].nodeValue;
w(value);
w("<br>");
//获取内容节点太复杂了,简化一点
var singleValue = div1.innerHTML;
w(singleValue);
w("<br>"); //直接访问内置的属性
w(div1.id);
w("<br>");
w(div1.className);
</script>

渲染结果

<div class="div">    HTML DOM</div><div class="div">DIV2</div>
<script>
    console.log("--getElementsByTagName--");    var element = document.getElementsByTagName("div");    for(var i = 0; i < element.length; i++){        console.log(element[i].innerText);    } 
    console.log("--querySelectorAll--");    element = document.querySelectorAll("div");    for(var i = 0; i < element.length; i++){        console.log(element[i].innerText);    }

    console.log("--querySelectorAll select class--");    element = document.querySelectorAll(".div");    for(var i = 0; i < element.length; i++){        console.log(element[i].innerText);    }  </script>

div1

DOM分类及HTML DOM的更多相关文章

  1. javascript中0级DOM和2级DOM事件模型浅析 分类: C1_HTML/JS/JQUERY 2014-08-06 15:22 253人阅读 评论(0) 收藏

    Javascript程序使用的是事件驱动的设计模式,为一个元素添加事件监听函数,当这个元素的相应事件被触发那么其添加的事件监听函数就被调用: <input type="button&q ...

  2. dom core,html dom,css dom,jquery 中的dom操作

    前端开发中为达到某种目的,往往有很多方法:dom core,html dom,jquery; dom core/jquery主要通过函数调用的方式(getAttribute("属性名&quo ...

  3. javascript中0级DOM和2级DOM事件模型浅析

    Javascript程序使用的是事件驱动的设计模式,为一个元素添加事件监听函数,当这个元素的相应事件被触发那么其添加的事件监听函数就被调用: <input type="button&q ...

  4. proxy 利用get拦截,实现一个生成各种DOM节点的通用函数dom。

    const dom = new Proxy({}, { get(target, property) { return function(attrs = {}, ...children) { const ...

  5. js学习总结:DOM节点二(dom基本操作)

    一.DOM继承树 DOM——Document Object Model DOM定义了表示修改文档所需要的方法.DOM对象即为宿主对象,由浏览器厂商定义,用来操作html和xml的一类厂商定义,也有人称 ...

  6. python 全栈开发,Day51(常用内置对象,函数,伪数组 arguments,关于DOM的事件操作,DOM介绍)

    昨日内容回顾 1.三种引入方式 1.行内js <div onclick = 'add(3,4)'></div> //声明一个函数 function add(a,b){ } 2. ...

  7. 全面理解虚拟DOM,实现虚拟DOM

    1.为什么需要虚拟DOM DOM是很慢的,其元素非常庞大,页面的性能问题鲜有由JS引起的,大部分都是由DOM操作引起的.如果对前端工作进行抽象的话,主要就是维护状态和更新视图:而更新视图和维护状态都需 ...

  8. 通俗易懂的来讲讲DOM——科普性质的DOM入门教程

    DOM这个东西很重要,不过初学的时候很容易蒙,什么Document.Element.Node用官方语言来解释根本就不是人话,只能在实践中硬着头皮一点一点尝试.今天要推荐的是一篇关于DOM的博客.说是教 ...

  9. 第一百六十七节,jQuery,DOM 节点操作,DOM 节点模型操作

    jQuery,DOM 节点操作,DOM 节点模型操作 学习要点: 1.创建节点 2.插入节点 3.包裹节点 4.节点操作 DOM 中有一个非常重要的功能,就是节点模型,也就是 DOM 中的“M”.页面 ...

随机推荐

  1. 风炫安全WEB安全学习第十七节课 使用Sqlmap自动化注入(一)

    风炫安全WEB安全学习第十七节课 使用Sqlmap自动化注入(一) sqlmap的使用 sqlmap 是一个开源渗透测试工具,它可以自动检测和利用 SQL 注入漏洞并接管数据库服务器.它具有强大的检测 ...

  2. .NET Core 中的日志与分布式链路追踪

    目录 .NET Core 中的日志与分布式链路追踪 .NET Core 中的日志 控制台输出 非侵入式日志 Microsoft.Extensions.Logging ILoggerFactory IL ...

  3. 安装weblogic 11g

    参考 https://blog.csdn.net/z69183787/article/details/38401013 https://blog.csdn.net/wjf8882300/article ...

  4. 解决Cannot find module '@angular/compiler-cli'

    前言: 今天clone之前做的一个angular项目,使用ng serve一直提示An unhandled exception occurred: Cannot find module '@angul ...

  5. mysql: Character set 'utf8mb4' is not a compiled character set and is not specified in the '/usr/share/mysql/charsets/Index.xml' file

    mysql: Character set 'utf8mb4' is not a compiled character set and is not specified in the '/usr/sha ...

  6. mysqldump 的-T参数

    /usr/local/mysql/bin/mysqldump -uroot -T /tmp lina xuehao 把lina数据库中的xuehao表在tmp目录下备份出来两个文件,一个是纯数据.tx ...

  7. 【Oracle】oracle pctfree和pctused详解

    oracle pctfree和pctused详解 一.建立表时候,注意PCTFREE参数的作用 PCTFREE:为一个块保留的空间百分比,表示数据块在什么情况下可以被insert,默认是10,表示当数 ...

  8. C# datagridview设置标题为汉语

    正常情况下,在给datagridview绑定数据源之后,显示的是SQL语句中的栏位,如下 我们想让标题显示汉语,可以有一下两种方法 1.在SQL中设置列别名 SELECT TITLE AS '报警标题 ...

  9. SAP中使用FTP服务

    SAP中简单的FTP技术实现基本上如下几个步骤: 1.SM59建立FTP的RFC destination. 可以通过执行SAP的标准程序RSFTP005,自动创建两个名为SAPFTP何SAPFTPA的 ...

  10. ECharts图表——封装通用配置

    前言 前段时间在做大屏项目,大量用到echarts图表,大屏对设计规范要求比较高,而大屏项目,经常会因为业务方面的原因.或者是数据方面的原因改动UI设计,所有图表的代码也是三天一小改.五天一大改 因此 ...