通过 HTML DOM,可访问 JavaScript HTML 文档的所有元素。
HTML DOM (文档对象模型)
当网页被加载时,浏览器会创建页面的文档对象模型(Document Object Model)。
HTML DOM 模型被构造为对象的树:
HTML DOM 树
通过可编程的对象模型,JavaScript 获得了足够的能力来创建动态的 HTML。
JavaScript 能够改变页面中的所有 HTML 元素
JavaScript 能够改变页面中的所有 HTML 属性
JavaScript 能够改变页面中的所有 CSS 样式
JavaScript 能够对页面中的所有事件做出反应
查找 HTML 元素
通常,通过 JavaScript,您需要操作 HTML 元素。
为了做到这件事情,您必须首先找到该元素。有三种方法来做这件事:
通过 id 找到 HTML 元素
通过标签名找到 HTML 元素
通过类名找到 HTML 元素
通过 id 查找 HTML 元素
在 DOM 中查找 HTML 元素的最简单的方法,是通过使用元素的 id。
本例查找 id="intro" 元素:
实例
var x=document.getElementById("intro");
如果找到该元素,则该方法将以对象(在 x 中)的形式返回该元素。
如果未找到该元素,则 x 将包含 null。
通过标签名查找 HTML 元素
本例查找 id="main" 的元素,然后查找 id="main" 元素中的所有 <p> 元素:
实例
var x=document.getElementById("main");
var y=x.getElementsByTagName("p");
通过类名找到 HTML 元素
本例通过 getElementsByClassName 函数来查找 class="intro" 的元素:
实例
var x=document.getElementsByClassName("intro");
HTML DOM 后篇
我会接着介绍:
如何改变 HTML 元素的内容 (innerHTML)
如何改变 HTML 元素的样式 (CSS)
如何对 HTML DOM 事件对出反应
如何添加或删除 HTML 元素
如您还有不明白的可以在下面与我留言或是与我探讨QQ群308855039,我们一起飞!
HTML DOM 节点
在 HTML DOM (Document Object Model) 中 , 每一个元素都是 节点:
文档是一个文档。
所有的HTML元素都是元素节点。
所有 HTML 属性都是属性节点。
文本插入到 HTML 元素是文本节点。are text nodes。
注释是注释节点。
Document 对象
当浏览器载入 HTML 文档, 它就会成为 document 对象。
document 对象是HTML文档的根节点与所有其他节点(元素节点,文本节点,属性节点, 注释节点)。
Document 对象使我们可以从脚本中对 HTML 页面中的所有元素进行访问。
提示:Document 对象是 Window 对象的一部分,可通过 window.document 属性对其进行访问。
浏览器支持
所有主要浏览器都支持 Document 对象。
Document 对象属性和方法
HTML文档中可以使用以上属性和方法:
属性 / 方法 | 描述 |
---|---|
document.activeElement | 返回当前获取焦点元素 |
document.addEventListener() | 向文档添加句柄 |
document.adoptNode(node) | 从另外一个文档返回 adapded 节点到当前文档。 |
document.anchors | 返回对文档中所有 Anchor 对象的引用。 |
document.applets | 返回对文档中所有 Applet 对象的引用。 |
document.baseURI | 返回文档的绝对基础 URI |
document.body | 返回文档的body元素 |
document.close() | 关闭用 document.open() 方法打开的输出流,并显示选定的数据。 |
document.cookie | 设置或返回与当前文档有关的所有 cookie。 |
document.createAttribute() | 创建一个属性节点 |
document.createComment() | createComment() 方法可创建注释节点。 |
document.createDocumentFragment() | 创建空的 DocumentFragment 对象,并返回此对象。 |
document.createElement() | 创建元素节点。 |
document.createTextNode() | 创建文本节点。 |
document.doctype | 返回与文档相关的文档类型声明 (DTD)。 |
document.documentElement | 返回文档的根节点 |
document.documentMode | 返回用于通过浏览器渲染文档的模式 |
document.documentURI | 设置或返回文档的位置 |
document.domain | 返回当前文档的域名。 |
document.domConfig | 返回normalizeDocument()被调用时所使用的配置 |
document.embeds | 返回文档中所有嵌入的内容(embed)集合 |
document.forms | 返回对文档中所有 Form 对象引用。 |
document. getElementsByClassName() | 返回文档中所有指定类名的元素集合,作为 NodeList 对象。 |
document.getElementById() | 返回对拥有指定 id 的第一个对象的引用。 |
document.getElementsByName() | 返回带有指定名称的对象集合。 |
document.getElementsByTagName() | 返回带有指定标签名的对象集合。 |
document.images | 返回对文档中所有 Image 对象引用。 |
document.implementation | 返回处理该文档的 DOMImplementation 对象。 |
document.importNode() | 把一个节点从另一个文档复制到该文档以便应用。 |
document.inputEncoding | 返回用于文档的编码方式(在解析时)。 |
document.lastModified | 返回文档被最后修改的日期和时间。 |
document.links | 返回对文档中所有 Area 和 Link 对象引用。 |
document.normalize() | 删除空文本节点,并连接相邻节点 |
document.normalizeDocument() | 删除空文本节点,并连接相邻节点的 |
document.open() | 打开一个流,以收集来自任何 document.write() 或 document.writeln() 方法的输出。 |
document.querySelector() | 返回文档中匹配指定的CSS选择器的第一元素 |
document.querySelectorAll() | document.querySelectorAll() 是 HTML5中引入的新方法,返回文档中匹配的CSS选择器的所有元素节点列表 |
document.readyState | 返回文档状态 (载入中……) |
document.referrer | 返回载入当前文档的文档的 URL。 |
document.removeEventListener() | 移除文档中的事件句柄(由 addEventListener() 方法添加) |
document.renameNode() | 重命名元素或者属性节点。 |
document.scripts | 返回页面中所有脚本的集合。 |
document.strictErrorChecking | 设置或返回是否强制进行错误检查。 |
document.title | 返回当前文档的标题。 |
document.URL | 返回文档完整的URL |
document.write() | 向文档写 HTML 表达式 或 JavaScript 代码。 |
document.writeln() | 等同于 write() 方法,不同的是在每个表达式之后写一个换行符。 |
警告 !!!
在 W3C DOM核心,文档对象 继承节点对象的所有属性和方法。
很多属性和方法在文档中是没有意义的。
HTML 文档对象可以避免使用这些节点对象和属性:
属性 / 方法 | 避免的原因 |
---|---|
document.attributes | 文档没有该属性 |
document.hasAttributes() | 文档没有该属性 |
document.nextSibling | 文档没有下一节点 |
document.nodeName | 这个通常是 #document |
document.nodeType | 这个通常是 9(DOCUMENT_NODE) |
document.nodeValue | 文档没有一个节点值 |
document.ownerDocument | 文档没有主文档 |
document.ownerElement | 文档没有自己的节点 |
document.parentNode | 文档没有父节点 |
document.previousSibling | 文档没有兄弟节点 |
document.textContent | 文档没有文本节点 |
如您还有不明白的可以在下面与我留言或是与我探讨QQ群308855039,我们一起飞!
家好,我是IT共享者,人称皮皮。
相信做网站对JavaScript再熟悉不过了,它是一门脚本语言,不同于Python的是,它是一门浏览器脚本语言,而Python则是服务器脚本语言,我们不光要会Python,还要会JavaScript,因为它对做网页方面是有很大作用的。
这是我们用的最普遍的一个文档对象了,专门用来操作DOM节点时用。
document.getElementById() #通过id查找HTML元素
document.getElementsByName() #通过name查找HTML元素
document.getElementsByTagName() #通过标签名查找HTML元素
document.getElementsByClassName() #通过类名查找HTML元素
document.querySelector(".h") #第一个类名为 "h" 的元素
document.querySelectorAll("div.no, div#h") #所有class为"no"或者id为"h"的div元素
document.body #获取body标签
document.documentElement #获取html标签
document.cookie #网页cookie
document.domain #文档的域名
document.lastModified #文档被最后修改的日期和时间
document.referrer #载入当前文档的文档的URL
document.title #当前文档的标题
document.URL #当前文档的URL
document.doctype #当前文档的doctype
document.baseURI #当前文档的绝对URI
document.documentMode #浏览器使用的模式
document.documentURI #文档的URI
document.implementation #DOM实现
document.inputEncoding #文档的编码(字符集)
document.readyState #文档的(加载)状态
document.strictErrorChecking #是否强制执行错误检查
document.write('hello world') 向文档写入文本
document.writeln('hello world') 向文档写入文本并换行
document.all #所有html元素
document.anchors #所有Anchor引用
document.forms #所有的表单引用
document.images #所有的图片引用
document.links #所有的超链接引用
document.scripts #所有的脚本引用
document.embeds #所有的流媒体引用
childNodes #获取子节点的集合 ,返回数组 ,并把换行和空格也当成是节点信息。
children #获取子节点的集合 ,返回数组
firstChild #获取第一个子元素 并把换行和空格也当成是节点信息
firstElementChild #获取第一个子节点
lastChild #获取最后一个子节点 并把换行和空格也当成是节点信息
lastElementChild #获取最后一个子节点
parentNode #获取父节点
parentElement #获取父节点(IE)
offsetParent #获取所有父节点 对应的值是body下的所有节点信息
previousSibling #获取上一个兄弟节点 匹配字符,包括换行和空格,而不是节点
previousElementSibling #获取上一个兄弟节点 直接匹配节点
nextSibling #获取下一个兄弟节点 匹配字符,包括换行和空格,而不是节点
nextElementSibling #获取下一个兄弟节点 直接匹配节点
ownerDocument #元素的根节点
这里我们获取到了所有的Div元素,我们可以针对性的获取一个ID下的Div的子元素以及它的兄弟和父,子元素,如下:
我们可以自定义节点并添加值,不过要将它添加到文档中去,所以必须添加节点,一般和下方的增加节点配套使用。
document.createElement(标签) #创建HTML元素
document.createTextNode(文本) #给文档添加文本
document.createComment(文本) #创建一个注释节点
document.createDocumentFragment() #创建文档粉碎节点
appendChild(节点) #节点被添加到元素的末尾
insertBefore(a,b) #a节点会插入b节点的前面
removeChild(节点名) #被移除的节点仍在文档中,只是文档中已没有其位置了
replaceChild(插入的节点,被替换的节点)
a.cloneChild() #复制a节点,复制出来的节点作为返回值为true时,则a元素后代也一并复制。否则,仅复制a元素本身
#节点类型 nodeType 有三种情况
#1.元素节点 2.属性节点 3.文本节点
#节点名称 nodeName
#节点值 nodeValue
#元素节点没节点值,为null
#文本节点的节点值就是文本
#属性节点的节点值就是该属性值
#节点属性获取
a.width
a['width']
a.gerAttribute(属性名) 返回指定的属性值
a.gerAttributeNode(属性名) 返回指定的属性节点
节点属性设置
a.width=400
a['width']=400
a.attributes['width']=400
a.setAttribute('width',400) 添加指定的属性
a.setAttributeNode(b) 添加指定的属性节点
#节点属性删除
a.removeChild(子节点) 从元素中移除子节点
a.removeAttribute(属性) 从元素中移除指定属性
a.removeAttributeNode(属性) 移除指定的属性节点,并返回被移除的节点
a.id 获取当前元素的id
a.className 获取当前元素的class
a.classList 获取当前元素的class列表
a.accessKey='w' 设置或返回元素的快捷键
a.namespaceURI 返回指定节点的命名空间的 URI
a.dir 设置或返回元素的内容是否可编辑
a.normalize() 合并元素中相邻的文本节点,并移除空的文本节点
a.tabIndex='3' 设置或返回元素的tab键控制次序
a.tagName 返回元素的标签名
a.textContent 设置或返回节点及其子代的文本内容
a.title 设置或返回元素的标题属性
a.item(num) 返回节点列表中位于指定下标的节点
a.length 返回节点列表中的节点数
a.innerHTML 获取或者设置对象内的HTML
a.innerText 获取或者设置对象内的文本
a.outerHTML 获取或者设置对象外的HTML
a.outerText 获取或者设置对象外的文本
a.value 获取或者设置表单元素的值
这篇文章主要介绍了JavaScript的文档对象。下一篇文章,我们继续介绍JavaScript,敬请期待!
*请认真填写需求信息,我们会在24小时内与您取得联系。