HTML DOM对象
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对象的更多相关文章
- HTML DOM 对象
本篇主要介绍HTML DOM 对象:Document.Element.Attr.Event等4个对象. 目录 1. Document 对象:表示文档树的根节点,大部分属性和方法都是对元素进行操作. 2 ...
- JavaScript实现DOM对象选择器
目的: 根据传入的选择器类型选出第一个符合的DOM对象. ①可以通过id获取DOM对象,例如 $("#adom"); ②可以通过tagName获取DOM对象,例如 $(" ...
- 判断一个对象是jQuery对象还是DOM对象
今天调试一段代码的时候,看到其中一个变量,想知道它到底是jquery对象还是dom对象. 虽然直接console出这个对象,看它的内部可以判断出来.但是我想有没有什么更方便的方法呢. 后来我想到了一个 ...
- 如何通过源生js获取一个元素的具体样式值 /* getCss:获取指定元素的具体样式的属性值 curElement:[dom对象] attr:[string] */
昨天的博客些的真的是惨不忍睹啊!!!但是我的人生宗旨就是将不要脸的精神进行到底,所以,今天我又来了.哈哈哈哈哈! 方法一:元素.style.属性名:(这个有局限性--只能获取行内样式的值,对于样式表或 ...
- 锋利的jQuery--jQuery与DOM对象的互相转换,DOM的三种操作(读书笔记一)
1.jQuery对象就是通过jQuery包装DOM对象后产生的对象. 2.jQuery对象和DOM对象的相互转换. 良好的书写风格: var $input=$("input" ...
- jQuery对象和DOM对象的区别
jQuery对象和DOM对象使用说明,需要的朋友可以参考下.1.jQuery对象和DOM对象第一次学习jQuery,经常分辨不清哪些是jQuery对象,哪些是 DOM对象,因此需要重点了解jQuery ...
- DOM对象与jQuery对象的相互转换
DOM 对象可以使用 js 中的方法, 不能使用jQuery中的方法:jQuery对象只能使用jQuery中的方法, 不能使用js中的方法:jQuery对象是通过jQuery包装DOM ...
- DOM对象—选中执行效果
---恢复内容开始--- 例如我们注册时,一些法律条例,我们是否同意决定着能否注册.在选择同意或不同意时出现的效果. 先在body里做一个按钮和选项框. <input type="ch ...
- jQuery对象与dom对象相互转换
核心提示:jquery选择器得到的jquery对象和标准的 javascript中的document.getElementById()取得的dom对象是两种不同的对象类型,一般情况下,如S('#id' ...
- 关于DOM对象与JQuery对象的那些事
这个问题源自上一次的工作室讨论班,主题是"jQuery选择器的使用",在讨论班的结尾,我留了一个思考题: jQuery获取到的对象和直接调用原生Javascript方法获得的对象 ...
随机推荐
- easyui datagriad 框架 自适应r
easyui datagriad 框架 在做列自适应时可以采取以下步骤: 1. fitColumns: true,/*自动扩大或缩小列的尺寸以适应表格的宽度并且防止水平滚动*/ 使之保持与父类宽度相同 ...
- apache开源项目--Lens
Lens 提供了一个统一数据分析接口.通过提供一个跨多个数据存储的单一视图来实现数据分析任务切分,同时优化了执行的环境.无缝的集成 Hadoop 实现类似传统数据仓库的功能. 该项目主要特性: 简单元 ...
- Java问题汇集(2)
1.Error setting driver on UnpooledDataSource 具体:Exception in thread "main" org.apache.ibat ...
- CSS和JS标签style属性对照表
盒子标签和属性对照 CSS语法(不区分大小写) JavaScript语法(区分大小写) border border border-bottom borderBottom border-bottom-c ...
- LinkedHashSet的实现原理
1. LinkedHashSet概述 LinkedHashSet是具有可预知迭代顺序的Set接口的哈希表和链接列表实现.此实现与HashSet的不同之处在于,后者维护着一个运行于所有条目的双重链接列表 ...
- loadrunner SQL2008
1. 下载 JDBC 驱动(sqljdbc4.jar) 2. 在 run-time setting 下的 classpath 把 JDBC 驱动引入 /* * LoadRunner Java scri ...
- ArrayLLis 线程不安 实验
这段代码演示了ArrayList的线程不安全,我让3个线程分别对list加入300个字符串,最后的arr的大小为800多,大家可以测试一下,我的一次是898,一次是897,同时还学了join的用法 i ...
- JDK1.5新特性(三)……Varargs
援引 Varargs - This facility eliminates the need for manually boxing up argument lists into an array w ...
- Weka 入门3
这次我们介绍Evaluation类.在上一次中我们只是单纯的预测了分类值,并没有其他评价数据.这场我们使用Evalution类.首先初始化一个Evaluation对象,Evaluation类没有无参的 ...
- 【Java基础】泛型的一些总结
什么是泛型 泛型其实可以理解为一种广泛的类型,啥类型都型,当然,这种泛是指定义时可以广泛,但是使用时必须确定类型.也就是说,当不清楚未来使用哪种类型时,定义为泛型.可以支持泛型类,泛型接口,泛型方法, ...