文档对象模型DOM
文档对象模型 DOM
1 DOM概述
1.1 什么是DOM
文档对象模型 Document Object Model 提供给用户操作document obj 的标准接口
文档对象模型 是表示和操作 HTML和XML文档内容的基础API
文档对象模型,是W3C组织推荐的处理可扩展标记语言的标准编程接口
1.2 DOM分类
核心 DOM - 针对任何结构化文档的标准模型
XML DOM - 针对 XML 文档的标准模型
HTML DOM - 针对 HTML 文档的标准模型
1.3 DOM树
2 节点
2.1 什么是节点
文档中的每一个部分都是节点,包括document 元素 属性 文本...
2.2 节点的分类
Doctype 文档类型
Document 文档
Element 元素
Attr 属性
Text 文本
Comment 注释
2.3 节点属性
nodeName 节点名字
nodeValue 节点值
nodeType 节点类型
2.3 节点常规操作
- var info_node = document.createAttribute("info"); // 创建
- console.log(info_node.nodeName);
- console.log(info_node.nodeType);
- info_node.value = '123'; // 设置
- console.log(info_node.nodeValue);
- sup1.setAttributeNode(info_node); // 添加
3 获取元素对象
3.1 通过js选择器
getElement系列
querySelector系列
4 文档结构和遍历文档
4.1 节点关系
父节点 父元素
子节点 子元素
同辈节点 同辈元素
祖先节点 祖先元素
后代节点 后代元素
4.2 作为节点树的文档
parentNode 父节点
childNodes 所有子节点的集合
firstChild 第一个子节点
lastChild 最后一个子节点
nextSibling 下一个兄弟节点
previousSibling 上一个兄弟节点
4.3 作为元素树的文档
parentElement 父元素(大部分情况下 parentElement 等同于 parentNode)
children 所有子元素的集合
firstElementChild 第一个子元素
lastElementChild 最后一个子元素
nextElementSibling 下一个兄弟元素
previousElementSibling 上一个兄弟元素
5 属性
5.1 HTML标签的属性和元素对象的属性
HTMLElement对象映射了元素的HTML属性
5.2 获取和设置非标准的HTML属性
getAttribute(attrname) 获取自定义或内置属性的值
setAttribute(attrnane, value) 设置自定义或内置属性
hasAttribute(attrname) 判断是否存在该属性
removeAttribute() 移出自定义或内置的属性
5.3 作为Attr节点的
setAttributeNode()
getAttributeNode()
document.createAttribute() 创建属性节点
- var attr = document.createAttribute('class');
- attr.value = 'active';
- box.setAttributeNode(attr);
6 元素的内容
6.1 作为HTML的元素内容
innerHTML
outerHTML
6.2 作为纯文本的元素内容
innerText 会忽略多余空白
6.3 作为Text节点的元素内容
文本节点的方法
- appendData() 向文本节点追加内容
- deleteData() 删除文本节点的一部分内容
- insertData() 向文本节点中插入内容
- replaceData() 替换内容
- substringData() 截取内容
创建文本节点
- document.createTextNode()
7 创建、插入、删除 元素节点
- // 操作步骤
- // 1. 创建div(元素节点)
- // 2. 设置div属性(单一css | css类名 | 文本 | 子标签 | 事件 | ...)
- // 3. 添加到(文档结构中)指定位置
7.1 创建节点
- document.createElement()
7.2 插入节点
- appendChild() 在元素的最后追加一个子元素
- insertBefore() 在元素指定的位置插入一个子元素
7.3 删除节点
- removeChild()
7.4 替换节点
- replaceChild(new_node, old_node)
7.5 克隆节点
- cloneNode()
- 参数
- true 克隆元素以及所有的厚点节点
- false 仅仅克隆节点本身
conclusion:
- // 创建:只能由document调用
- var box = document.createElement('div');
- // 在body元素的最后追加一个子元素
- body.appendChild(box);
- // 在body元素oldEle之前插入一个子元素
- body.insertBefore(box, oldEle);
- // 从body中删除box元素,可以接受返回值,就是删除的元素
- var res = body.removeChild(div);
- // 将body中oldEle元素替换为box,可以接受返回值,就是被替换的元素
- res = bodyreplaceChild(box, oldEle);
- // true深拷贝,拷贝自身与内容, false浅拷贝,只拷贝自身标签
- box.cloneNode()
8 Document对象
每个载入浏览器的 HTML 文档都会成为 Document 对象。 Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。
8.1 属性
- URL 获取当前页面的url 只读
- domain 获取域名
- referrer 获取上一个页面的地址 只读
- title 标签标题
- location 网站地址信息
- lastModified 最后一次修改事件
- cookie
8.2 方法
- write()
- writeln()
9 事件对象target属性
- // ev.target通过父级的事件对象,获取具体相应区域位置的子级元素
- // 应用场景
- // 1. 父级的子元素类型不同一,采用循环绑定不方便
- // 2. 父级子元素较多或不确定
文档对象模型DOM的更多相关文章
- JavaScript编程:文档对象模型DOM
5.文档对象模型DOM JS里的DOM和XML里的DOM不同,但是解析方式是一样的. document.getElementByID("id")根据ID获得元素节点. 创建和操作节 ...
- 认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法。元素、属性和文本的树结构(节点树)。
认识DOM 文档对象模型DOM(Document Object Model)定义访问和处理HTML文档的标准方法.DOM 将HTML文档呈现为带有元素.属性和文本的树结构(节点树). 先来看看下面代码 ...
- 文档对象模型DOM通俗讲解
转自:http://www.jb51.net/article/42671.htm 在开始之前先说一点,DOM是非常容易理解的,但是大家说的太官方,让人很是难于理解,我们就用非常简单的语言翻译一遍.加深 ...
- JavaScript的文档对象模型DOM
小伙伴们之前我们讲过很多JavaScript的很多知识点,可以点击回顾一下: <JavaScript大厦之JS运算符>: <JavaScript工作原理:内存管理 + 如何处理4个常 ...
- 第10章 文档对象模型DOM 10.1 Node节点类型
DOM是针对 HTML 和 XML 文档的一个 API(应用程序编程接口) .DOM描绘了一个层次化的节点树,允许开发人员添加.移除和修改页面的某一部分.DOM 脱胎于Netscape 及微软公司创始 ...
- 第10章 文档对象模型DOM 10.2 Document类型
Document 类型 JavaScript 通过 Document 类型表示文档.在浏览器中, document 对象是 HTMLDocument (继承自 Document 类型)的一个实例,表示 ...
- 第10章 文档对象模型DOM 10.3 Element类型
Element 类型用于表现 XML或 HTML元素,提供了对元素标签名.子节点及特性的访问. 要访问元素的标签名,可以使用 nodeName 属性,也可以使用 tagName 属性:这两个属性会返回 ...
- 文档对象模型DOM(二)
练习: 要求:界面上有个登录按钮,点击登录的时候,界面中弹出一个登录的方框,点击登录方框中的×的,登录方框消失. <!DOCTYPE html> <html> <head ...
- 文档对象模型DOM(一)
当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model). HTML DOM 模型被构造为对象的树. HTML DOM 树 每加载一个标记 注释 或者属性,就将其当 ...
随机推荐
- CentOS7 zabbix服务 简单安装文档
1. 简介 zabbix是一个基于WEB界面的提供分布式系统监视以及网络监视功能的企业级的开源解决方案. zabbix能监视各种网络参数,保证服务器系统的安全运营:并提供灵活的通知机制以让系统管理员快 ...
- centos 文件新建、删除、移动、复制等命令
创建目录 mkdir 文件名 mkdir /var/www/test cp复制命令 cp命令复制文件从一个位置到另一位置.如果目的地文件存在,将覆复写该文件: 如果目的地目录存在,文件将复制到该目录下 ...
- java课上测试心得
放暑假之前,建民老师就给我们布置了每一天学习两小时的代码,但是自己的不重视,根本就没有达到这个要求,简单学了一点点基本的东西,然后在开学的第一堂课上,连续三个小时的敲代码,让我意识到了自己的问题,一个 ...
- 前端页面报net::ERR_CONNECTION_RESET错误的原因
本机和测试环境都是OK的.但是一到线上就报错:可能原因总结如下: 1 可能是服务器限制了文件上传的权限. 解决方法:开通了文件上传权限. 2 也许导致这种错误的方式有很多,可能是因为post请求时提交 ...
- Inferred type 'S' for type parameter 'S' is not within its bound;
在使用springboot 方法报错: Inferred type 'S' for type parameter 'S' is not within its bound; should extends ...
- 怎样从外网访问内网Node.js?
本地安装了一个Node.js,只能在局域网内访问,怎样从外网也能访问到本地的Node.js呢?本文将介绍具体的实现步骤. 1. 准备工作 1.1 安装并启动Node.js 默认安装的Node.js端口 ...
- 每日linux命令学习-head命令和tail命令
本节主要学习了linux文件浏览的相关命令,包括cat.less.more.read.tail等,由于本人经常使用cat.less.more命令,已经较为熟悉,所以本节重点学习head命令和tail命 ...
- Qt 文本文件的打开、新建、保存以及另存为
我们平时在使用windows的notepad以及其他各种软件过程中,都会有保存文件和另存为两种功能,这两者不能混为一谈. 一.保存时有两种情况,一种是对于新创建的文件,一种是对于已有的文件,前者需要打 ...
- Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践
Spring Boot 2 (五):Docker Compose + Spring Boot + Nginx + Mysql 实践 Spring Boot + Nginx + Mysql 是实际工作中 ...
- rhel 6 version `GLIBC_2.14' not found (required by /usr/lib64/libstdc++.so.6)以及libstdc++.so.6: version GLIBCXX_3.4.18 not found解决办法
最近在oracle linux 7.3下开发了个应用,发布到rhel 6.5运行的时候,报version `GLIBC_2.14' not found (required by /usr/lib64/ ...