全栈JavaScript之路( 二十四 )DOM2、DOM3, 不涉及XML命名空间的扩展
版权声明:本文为博主原创文章。未经博主同意不得转载。 https://blog.csdn.net/hatmore/article/details/37658167
(一)DocumentType 类型的变化新增三个属性: publicId,systemId,internalSubset(内部子集)
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Strict//EN"
"http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd"
[<!ELEMENT name (#PCDATA)>] >
通过, document.doctype.publicId,document.doctype.systemId,document.doctype.internalSubset ,能够訪问到。
訪问document.doctype.internalSubset 将得到"<!ELEMENT name (#PCDATA)>"。
这样的内部子集(internal subset)在HTML 中极少用到,在XML 中可能会更常见一些。
(二)Document 类型与 xml命名无关的变化 的是。importNode() 方法。这种方法是从一个文档中取出一个节点。放到还有一文档。成为其一部分。
须要注意的是,每个节点都有一个ownerDocument属生,假设用appendChild(node) 方法,传入的节点不是同一个文档的会报错。
importNode()方法与cloneNode()方法非常像。接受两个參数,一个是要导入的几点,一个是个布尔值,表示是否要导入子节点。
var newNode = document.importNode(oldNode,true)//导入全部子节点
document.body.appendChild(newnode)
在DOM2,视图模块 添加了一个唯一的属性,defaultView ,指向文档的窗体(或者框架)。在IE中有个等级的属性 parentWindow ,假设要确定文档的窗体:
var parentWindow = document.defaultView || document.parentWindow
除了 importNode()方法,defaultView 属性之外。还添加了两个方法:
document.implementation.createDocumentType(文档类型名称,publicId,systemId) ,因为既有的文档类型不能改动,所以仅仅能在创建新的文档的时候调用这种方法。
document.implementation.createDocument(namaspaceURL,root,doctype);
样例:
var doctype = document.implementation.createDocumentType("html","-//W3C//DTD XHTML 1.0 Strict//EN","http://www.w3.org/TR/xhtml1/DTD/xhtml1-strict.dtd")
var doc = document.implementation.createDocument("http://www.w3.org/1999/xhtml",
"html", doctype);
(三) Node 类型的变化 新增了一个 与 命名空间无关的方法, isSupported()方法 。与dom1 中的 document.hasFeature() 方法类似,确定当前节点拥有什么能力。
只是。还是建议用能力检測。
样例:
if(document.body.isSupported('html','2.0')) {
//...
}
DOM3 还为节点引用了isSameNode(), isEqualNode(),
这两个方法都接受一个节点參数,并在传入节点与引用的节点同样或相等时返回true。
所谓同样,指的是两个节点引用的是同一个对象。
所谓相等,指的是两个节点是同样的类型。具有相等的属性(nodeName、nodeValue,等等),并且它们的attributes 和childNodes 属性也相等(同样位置包括同样的值)。
DOM3 还针对 为Node 加入额外数据引入了新方法 setUserData(),该方法会把数据指定给节点,接受三个參数: 键,值。处理函数。
document.body.setUserData("name","100",function(opration,key,value,srcNode,destNode){})
然后用 var v alue = document.body.getUserData("name") ,就取得了值。
setUserData() ,的 回调函数,有5个參数,
- 操作类型: 1复制。2导入,3删除。4重命名
- 数据键
- 数据值
- 源节点
- 目标节点
传入setUserData()中的 处理函数 (回调函数)会在带有数据的节点被复制、删除、重命名或引入一个文档时调用,因而你能够事先决定在上述操作发生时怎样处理用户数据。
(四) 框架的变化
框架与内框架 分虽用 HTMLFrameElement, HTMLIframeElement 表示,他们在dom2 中都有一个新属性: contentDocument
var iframe = document.getElementById("myIframe");
var iframeDoc = iframe.contentDocument; //IE8之前无效
conentDocument 对象是 Document类型的实例,因此能够像使用document 对象一样使用它, 包括全部属性与方法。
IE8 之前不支持 框架的 contentDocment属性,但支持 contentWindow 属性。
因此:
var iframe = document.getElementById("myIframe");
var iframeDoc = iframe.contentDocument || iframe.contentWindow.document;
全栈JavaScript之路( 二十四 )DOM2、DOM3, 不涉及XML命名空间的扩展的更多相关文章
- 全栈JavaScript之路(十四)HTML5 中与class属性相关的扩充
1. getElementByClassName() :支持getElementsByClassName()方法的浏览器有IE 9+.Firefox 3+.Safari 3.1+.Chrome 和 O ...
- 全栈JavaScript之路(十九)HTML5 插入 html标记 ( 一 )innerHTML 与outerHTML
在须要给文档插入大量的html 标记下.通过DOM操作非常麻烦,你不仅要创建一系列的节点,并且还要小心地依照顺序把它们接结起来. 利用html 标签 插入技术,能够直接插入html代码字符串,简单.高 ...
- 全栈JavaScript之路(十八)HTML5 自己定义数据属性
HTML5 规范规定,用户能够为元素 自己定义非标准属性, 可是要加入 data- 前缀. 目的是为元素提供与页面渲染无关的信息.或者语义信息.这些属性名能够任意加入,仅仅要带上前缀 data- 开头 ...
- 全栈JavaScript之路(十六)HTML5 HTMLDocument 类型的变化
HTML5 扩展了 HTMLDocument, 添加了新的功能. 1.document.readState = 'loading' || 'complete' //支持readyState 属性的浏 ...
- 全栈JavaScript之路(十)学习 DocumentFragment 类型 节点
DocumentFragment 类型节点,代表一个文档片段,是一种轻量级的'文档' 对象.能够包括其他类型节点,并有能力訪问.操作当中的节点,可是在文档中没有文档标记,相当于是一个页面不可见的容器. ...
- “全栈2019”Java多线程第二十四章:等待唤醒机制详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- “全栈2019”Java多线程第十四章:线程与堆栈详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...
- “全栈2019”Java异常第十四章:将异常输出到文本文件中
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java异 ...
- “全栈2019”Java第八十四章:接口中嵌套接口详解
难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java第 ...
随机推荐
- 原来,多年以来,我一直是个curl/CRUD程序员
curl,就是create,update,remove,list的首字母简写.说是CRUD似乎更流行些,不过无所谓,知道是一个意思就好. curl程序员,就是增改删查程序员,中文说增删改查更加顺口. ...
- Laravel之哈希/常用函数/分页
一.哈希 1.简介Laravel Hash 门面为存储用户密码提供了安全的Bcrypt 哈希算法.如果你正在使用Laravel 应用自带的AuthController 控制器,将会自动为注册和认证使用 ...
- OpenCV入门学习(三)HistogramEquivalent
直方图均衡 #include <opencv2\core\core.hpp> #include <opencv2\highgui\highgui.hpp> #include & ...
- R 介绍
R定义:一个能够自由有效地用于统计计算和绘图的语言和环境,它提供了广泛的统计分析和绘图技术. R语言的使用很大程度上可以说是借助各种各种各样R包的辅助,从某种程度上说,运用R的插件来满足不同的需求. ...
- shell脚本检测网络是否畅通
shell初始化安装脚本执行时,需从网络上安装一些rpm包,所有需要先检测网络的畅通性, 代码 #检测网络链接&&ftp上传数据 function networkAndFtp() { ...
- winform对话框拖拽显示文件路径的问题
allow drop=true; dragEnter dragDrop vs管理员账户拖拽会失败
- 解决PHP显示Warning和Notice等问题
PHP在安装后,会在php.ini 文件中设置报错.提醒.警告等方式的出现,这样的方式可以使我们在调试PHP程序的时候能及时了解程序所存在的问题.然后,有时候我们并不需要提醒.警告 等内容,比如当我们 ...
- 安装MacOS到虚拟机
[TOC] 系统版本历史 4. 升级系统到10.12.6版本 时间:2017年9月21日 15:58:55 大小:VMDK(7.63 GB) 变动: 升级系统到10.12.6版本 3. 降低内存到6G ...
- centos root登录password 忘记解决的方法
Centos系统 登陆root忘记password 解决方式: (1)开机启动系统,在进入linux系统之前按键Esc 进入例如以下界面:(须要注意:Centos是安装在虚拟机里面的话,须要将鼠标点进 ...
- C# SqlBulkCopy类批量导入数据
特别注意 sqlbulkcopy.ColumnMappings.Add(dt.Columns[i].ColumnName, dt.Columns[i].ColumnName); 插入的时候列的顺序可 ...