HTML DOM对象

Document对象
每个载入浏览器的HTML文档都会成为Document对象
Document对象让我们可以从javascript中操作文档中的所有元素
Document对象是window对象的一部分,可以通过window.document 对其进行访问

Document对象集合
all[]                提供对文档中所有html元素的访问,返回数组
anchors[]            返回文档中所有Anchor对象(锚点)的引用,返回数组
applets             返回文档中所有applet对象的引用
forms[]                返回文档中所有form对象的引用
images[]            返回文档中所有image对象引用
links[]                返回文档中所有 Area 和 Link对象引用

Document对象属性
body                 对body元素的直接访问,对于定义了框架集的文档,该属性引用最外层的 frameset
cookie                设置或返回当前文档有关的所有cookie,可读可写
domain                 返回当前文档的域名
lastModified         返回文档被最后修改的时间和日期
referrer             返回载入当前文档的文档的URL
title                 返回当前文档的标题
URL                 返回当前文档的URL,当前实际显示的URL

Document对象方法
open()                    打开一个流,以收集来自任何 document.write() 或 document.writeln() 方法的输出
close()                 关闭一个由 document.open 方法打开的输出流,并显示选定的数据
getElementById()        返回对拥有指定id的第一个对象的引用
getElementsByName()        返回指定名称的对象集合
getElementsByTagName()    返回指定标签的对象集合
write()                 向文档写html表达式 或 javascript 代码
writeln()                 等同于write(),不同的是在每个表达式后写一个换行符

Element对象
Element对象 表示 HTML元素
NodeList 对象表示节点列表,比如HTML元素的子节点集合
所有浏览器都支持 Element对象 和 NodeList对象
属性和方法
element.accessKey                        设置或返回元素的快捷键
element.appendChild()                     向元素添加最后一个子节点,作为最后一个子节点
element.attributes                         返回元素属性的集合
element.childNodes                         返回元素子节点的节点列表
element.className                         设置或返回元素的class属性

element.clientHeight                     返回元素的可见高度(不包括padding以外的,包括padding)
element.clientWidth                     返回元素的可见宽度

element.cloneNode()                     创建节点的拷贝,并返回该副本,如需要克隆所有后代,需要参数true,如果只需要克隆节点以及后代(不包括属性值),设置为false。
element.compareDocumentPosition()         比较两个元素的文档位置
element.contentEditable                 设置或返回元素内容是否可编辑,true 是可编辑
element.dir                             设置或返回元素的文本方向
element.firstChild                         返回指定节点的首个子节点
element.getAttribute()                    返回元素节点的指定属性值
element.getAttributeNode()                 返回指定的属性节点(和getAttribute类似)
element.getElementsByTagName()            返回指定标签名的集合,return 数组
element.getFeature()                     返回实现了指定特性的API的某个对象
element.getUserData()                     返回关联元素上键的对象
element.hasAttribute()                    如果元素拥有指定属性,则返回true,否则返回false
element.hasAttributes()                    如果元素拥有属性,则返回true,否则返回false,检测元素是否拥有属性
element.hasChildNodes()                 如果元素有子节点,则返回true,否则false,检测元素是否有子节点
element.id                                 设置或返回元素的id

element.innerHTML                        设置或返回元素的内容
element.insertBefore()                     在指定的已有的子节点前插入新节点
element.isContentEditable                 返回元素的内容是否可编辑
element.isDefaultNamespace()             如果指定的namespaceURL是默认的,则返回true,否则返回false
element.isEqualNode()                     检查两个元素是否相等
element.isSameNode()                     检查两个元素是否是相同的节点
element.isSupported()                     如果元素支持指定特性,则返回true
element.lang                             设置或返回元素的语言代码
element.lastChild                         返回元素的最后一个子元素
element.namespaceURI                     返回元素的namespace URI
element.nextSibling                        返回位于相同节点树层级的下一个节点,返回列表项的下一个同胞
element.nodeName                         返回元素的名称
element.nodeType                         返回元素的节点类型
element.nodeValue                         设置或返回元素值
element.normalize()                     合并元素中相邻的文本节点,并移除空的文本节点,个人理解恢复原文本节点数(这个很有意思哦)

element.offsetHeight                    返回元素的高度(包括border)
element.offsetWidth                     返回元素的宽度
element.offsetLeft                         返回元素的水平偏移位置(根据body来计算这个偏移)
element.offsetTop                         返回元素的垂直偏移位置
element.offsetParent                     返回元素的偏移容器(偏移容器是body)

element.ownerDocument                     返回元素的根元素(文档对象)
element.parentNode                         返回元素的父节点,如果没有父节点,则返回null
element.previousSibling                 返回位于相同节点树层级的前一个元素,返回列表项的上一个同胞
element.removeAttribute()                 从元素中移除指定属性
element.removeAttributeNode()             移除指定的属性节点,并返回被移除的节点
element.removeChild()                     从元素中移除子节点
element.replaceChild()                     替换元素中的子节点
element.scrollHeight                     返回元素的整体高度(不包括border,包括padding)
element.scrollLeft                         返回元素左边缘与视图之间的距离
element.scrollTop                         返回元素上边缘与视图之间的距离(子元素超过当前元素的高度)一定是超过本元素的哦
element.scrollWidth                     返回元素的整体宽度

element.setAttribute()                     把指定属性设置或更改为指定值
element.setAttributeNode()                 设置或更改指定属性节点
element.setIdAttribute()                 
element.setIdAttributeNode()
element.setUserData()                     把对象关联到元素的键
element.style                             设置或返回元素的style属性
element.tabIndex                        设置或返回元素的tab键控制次序
element.tagName                         返回元素的标签名
element.textContent                     设置或返回节点以及其后代的文本内容
element.title                             设置或返回元素的title属性
element.toString()                         把元素转换为字符串
nodelist.item()                         返回NodeList中位于指定下标的节点
nodelist.length                            返回NodeList中的节点数

Attribute 对象(属性对象)
NamedNodeMap 对象表示元素属性节点的无序集合,可以通过名称和索引来访问
属性/方法
attr.isId                                 查明属性是否是元素的id属性,是则返回true,否则返回false
attr.name                                 返回属性的名称
attr.value                                 设置或返回属性的值
attr.specified                            是否制定某个属性,如果指定返回true,否则返回false

nodemap.getNameItem()                     从 NameNodeMap 返回指定的属性节点
nodemap.item()                             从 NameNodeMap 中位于指定下标的节点
nodemap.length                             返回 NamedNodeMap 中的节点数
nodemap.removeNamedItem()                 移除指定的属性节点,和返回指定的属性节点相对应
nodemap.setNamedItem()                     设置指定的属性节点(通过名称),如果此节点已存在,则将特换该节点,并返回被替换的节点,否则返回null

event 对象(事件)
事件通常与函数结合使用,函数通常在事件后执行
********事件发生在何时。。时间句柄 ***********
onabort                            图像的加载被中断时发生
onblur                            元素失去焦点时
onchange                        域的内容被改变时
onclick                         当用户点击某个对象时调用的事件句柄
ondblclick                        当用户双击某个对象时调动的事件句柄
onerror                            在加载文档或图像时发生错误(例如引入的图片不存在)
onfocus                         对象获得焦点
onkeydown                         某个键盘键被按下
onkeypress                        某个键盘按键被按下并松开
onkeyup                         某个键盘按键被松开
onload                             一张页面或一副图像完成加载
onmousedown                     鼠标按钮被按下
onmousemove                     鼠标被移动(在元素上就一直有效)
onmouseout                         鼠标从某元素移开
onmouseover                     鼠标移到某元素之上
onmouseup                         鼠标按键被松开
onreset                         重置按钮被点击
onresize                         窗口或框架被重新调整大小时发生,window对象
onselect                        文本被选中
onsubmit                         表单的确认按钮被点击时发生
onunload                         用户退出页面时发生 (无法使用)

鼠标/键盘属性
altKey                            返回当事件被触发时,alt是否被按住,返回布尔值
button                            返回当事件被触发时,哪个鼠标按钮被点击(0 是鼠标左键,1 是鼠标中键,2是鼠标右键)
IE 下 (1是鼠标左键, 4是鼠标中键, 2是鼠标右键), 火狐的 ctrl + click 参数是2(等价于右键)
clientX                            返回当前事件触发时,鼠标指针的水平坐标(相对于浏览器边缘来说的)
clientY                            返回当前事件触发时,鼠标指针的垂直坐标
metaKey                            返回当前事件触发时,meta 键是否被按下,不支持 IE
relatedTarget                    返回与事件的目标节点相关的节点
screenX                            返回当某个事件触发时,鼠标指针的水平坐标(相对于视口的:例如浏览器)
screenY                            返回当某个事件触发时,鼠标指针的垂直坐标
shiftKey                        返回当事件被触发时, shift 键是否被按下

IE属性
除了上面的鼠标/事件属性,IE还支持下面的属性
cancelBubble                    如果事件句柄想阻止事件传播到包容对象,必须将该属性设置为true
fromElement                        对于 mouseover 和 mouseout 事件,fromElement 引用移出鼠标的元素。
keyCode                            对于 keypress 事件,该属性声明了被敲击的键生成的 Unicode 字符码。对于 keydown 和 keyup 事件,它指定了被敲击的键的虚拟键盘码。虚拟键盘码可能和使用的键盘的布局相关。
offsetX,offsetY                    发生事件的地点在事件源元素的坐标系统中的 x 坐标和 y 坐标。
returnValue                        如果设置了该属性,它的值比事件句柄的返回值优先级高。把这个属性设置为 fasle,可以取消发生事件的源元素的默认动作。
srcElement                        对于生成事件的 Window 对象、Document 对象或 Element 对象的引用。
toElement                        对于 mouseover 和 mouseout 事件,该属性引用移入鼠标的元素。
x,y                                事件发生的位置的 x 坐标和 y 坐标,它们相对于用CSS动态定位的最内层包容元素。

标准 Event属性(2级DOM事件标准定义的属性)
bubbles                            指定事件是否是起泡事件类型,返回布尔值。IE不支持
cancelable                        指定事件是否拥有可取消的默认动作,返回布尔值。IE不支持
currentTarget                    返回其事件监听器触发该事件的元素,个人理解:就是返回当前触发事件的元素
eventPhase                        返回事件传播的当前阶段,分别为捕获阶段、正常事件派发和起泡阶段
Event.CAPTURING_PHASE            1
Event.AT_TARGET                    2
Event.BUBBLING_PHASE            3
target                             返回触发此事件的元素(事件的目标节点)
timeStamp                         返回事件生成的日期和事件、返回系统启动至今的分钟数(IE不支持),并非所有系统都提供该信息
type                             返回当前event事件表示的事件名称(IE不支持)

标准Event方法(2级DOM事件标准定义的方法,IE的时间模型不支持这些方法)
initEvent()                        初始化新创建的Event对象的属性
preventDefault()                 取消事件的默认动作
stopPropagation()                 不再派发事件,终止事件在传播过程的捕获,目标处理或起泡阶段进一步传播

事件传播:
在2级DOM中,事件传播分为三个阶段
第一,捕获阶段。事件从Document对象沿着文档树向下传递给目标节点,如果目标的任何一个先辈专门注册了捕获事件句柄,那么在事件传播过程中运行这些句柄。
第二个阶段发生在目标节点自身,直接注册砸目标上的适合的事件句柄将运行。这与0级事件模型提供的事件处理方法相似
第三,起泡阶段,在此阶段,事件将从目标元素向上传播回或起泡回Document对象的文档层次

HTML DOM对象的更多相关文章

  1. HTML DOM 对象

    本篇主要介绍HTML DOM 对象:Document.Element.Attr.Event等4个对象. 目录 1. Document 对象:表示文档树的根节点,大部分属性和方法都是对元素进行操作. 2 ...

  2. JavaScript实现DOM对象选择器

    目的: 根据传入的选择器类型选出第一个符合的DOM对象. ①可以通过id获取DOM对象,例如 $("#adom"); ②可以通过tagName获取DOM对象,例如 $(" ...

  3. 判断一个对象是jQuery对象还是DOM对象

    今天调试一段代码的时候,看到其中一个变量,想知道它到底是jquery对象还是dom对象. 虽然直接console出这个对象,看它的内部可以判断出来.但是我想有没有什么更方便的方法呢. 后来我想到了一个 ...

  4. 如何通过源生js获取一个元素的具体样式值 /* getCss:获取指定元素的具体样式的属性值 curElement:[dom对象] attr:[string] */

    昨天的博客些的真的是惨不忍睹啊!!!但是我的人生宗旨就是将不要脸的精神进行到底,所以,今天我又来了.哈哈哈哈哈! 方法一:元素.style.属性名:(这个有局限性--只能获取行内样式的值,对于样式表或 ...

  5. 锋利的jQuery--jQuery与DOM对象的互相转换,DOM的三种操作(读书笔记一)

    1.jQuery对象就是通过jQuery包装DOM对象后产生的对象.   2.jQuery对象和DOM对象的相互转换.   良好的书写风格: var $input=$("input" ...

  6. jQuery对象和DOM对象的区别

    jQuery对象和DOM对象使用说明,需要的朋友可以参考下.1.jQuery对象和DOM对象第一次学习jQuery,经常分辨不清哪些是jQuery对象,哪些是 DOM对象,因此需要重点了解jQuery ...

  7. DOM对象与jQuery对象的相互转换

    DOM  对象可以使用 js       中的方法,  不能使用jQuery中的方法:jQuery对象只能使用jQuery中的方法, 不能使用js中的方法:jQuery对象是通过jQuery包装DOM ...

  8. DOM对象—选中执行效果

    ---恢复内容开始--- 例如我们注册时,一些法律条例,我们是否同意决定着能否注册.在选择同意或不同意时出现的效果. 先在body里做一个按钮和选项框. <input type="ch ...

  9. jQuery对象与dom对象相互转换

    核心提示:jquery选择器得到的jquery对象和标准的 javascript中的document.getElementById()取得的dom对象是两种不同的对象类型,一般情况下,如S('#id' ...

  10. 关于DOM对象与JQuery对象的那些事

    这个问题源自上一次的工作室讨论班,主题是"jQuery选择器的使用",在讨论班的结尾,我留了一个思考题:  jQuery获取到的对象和直接调用原生Javascript方法获得的对象 ...

随机推荐

  1. easyui datagriad 框架 自适应r

    easyui datagriad 框架 在做列自适应时可以采取以下步骤: 1. fitColumns: true,/*自动扩大或缩小列的尺寸以适应表格的宽度并且防止水平滚动*/ 使之保持与父类宽度相同 ...

  2. apache开源项目--Lens

    Lens 提供了一个统一数据分析接口.通过提供一个跨多个数据存储的单一视图来实现数据分析任务切分,同时优化了执行的环境.无缝的集成 Hadoop 实现类似传统数据仓库的功能. 该项目主要特性: 简单元 ...

  3. Java问题汇集(2)

    1.Error setting driver on UnpooledDataSource 具体:Exception in thread "main" org.apache.ibat ...

  4. CSS和JS标签style属性对照表

    盒子标签和属性对照 CSS语法(不区分大小写) JavaScript语法(区分大小写) border border border-bottom borderBottom border-bottom-c ...

  5. LinkedHashSet的实现原理

    1. LinkedHashSet概述 LinkedHashSet是具有可预知迭代顺序的Set接口的哈希表和链接列表实现.此实现与HashSet的不同之处在于,后者维护着一个运行于所有条目的双重链接列表 ...

  6. loadrunner SQL2008

    1. 下载 JDBC 驱动(sqljdbc4.jar) 2. 在 run-time setting 下的 classpath 把 JDBC 驱动引入 /* * LoadRunner Java scri ...

  7. ArrayLLis 线程不安 实验

    这段代码演示了ArrayList的线程不安全,我让3个线程分别对list加入300个字符串,最后的arr的大小为800多,大家可以测试一下,我的一次是898,一次是897,同时还学了join的用法 i ...

  8. JDK1.5新特性(三)……Varargs

    援引 Varargs - This facility eliminates the need for manually boxing up argument lists into an array w ...

  9. Weka 入门3

    这次我们介绍Evaluation类.在上一次中我们只是单纯的预测了分类值,并没有其他评价数据.这场我们使用Evalution类.首先初始化一个Evaluation对象,Evaluation类没有无参的 ...

  10. 【Java基础】泛型的一些总结

    什么是泛型 泛型其实可以理解为一种广泛的类型,啥类型都型,当然,这种泛是指定义时可以广泛,但是使用时必须确定类型.也就是说,当不清楚未来使用哪种类型时,定义为泛型.可以支持泛型类,泛型接口,泛型方法, ...