JavaScript处理HTML DOM
本来只想好好写一篇博文,最后弄到好像重构一样了,越做越不满意,先这样吧:)
document.getElementById(id)
document.getElementsByTagName(name)
Object Collections: x.elements[index]+
x为以下元素:document.anchors、document.body、document.documentElement、document.embeds、documen.forms、document.head、document.images、document.links、document.scripts、document.title。只对特定元素,如document.forms的elements只获取表单元素。
document.getElementsByName(name)+
[lte IE 9]将id和name混为一谈,所以要有好习惯,id和name用相同名字
document.allOnly [IE]
document.querySelector()[gte IE 8]
document.querySelectorAll()[gte IE 8]+
不把文本节点算进
document.getElementsByClassName(class)[gte IE 9]+
参数为"*"时返回全部
document.firstElementChild()[gte IE 9]+
不把文本节点算进来
document.lastElementChild()[gte IE 9]+
不把文本节点算进来
document.nextElementSibling()[gte IE 9]+
不把文本节点算进来
document.previousElementSibling()[gte IE 9]+
不把文本节点算进来
document.childElementCount()[gte IE 9]+
不把文本节点算进来,子节点个数
element.innerHTML
element.attributeName
element.setAttribute(attr, value)
element.getAttribute()
element.removeAttribute()
element.style.propertyName
element.innerText+
FF不支持,其他支持,IE引入,为空时返回""
element.textContent+
[lte IE 8]不支持,其他支持,FF引入,注意,相比innerText,这个会保留前后空格,如换行等造成的空格,为空时返回undefined
document.createElement()
document.createComment()
document.createAttribute()
document.createTextNode()
document.createDocumentFragment()
document.removeChild()+
返回被删除元素
document.appendChild()
document.replaceChild()+
返回被替换元素
parentElement.insertBefore(new, old)
cloneNode()+
?
hasChildNodes()
document.write()+
注意文档加载完毕后使用会重写整个文档
element.onclick = function(){ code }
element.addEventListener("click", funcName[, useCapture])+
useCapture设置使用bubbleing(true)或者capturing(false),前者事件触发由里到外,后者则由外到里,如果要在方法里传参数需要这样定义:function(){ funcName(a, b); },笔者试过若直接写funcName(a, b),加载时这个方法会执行一次的,相比onclick=的方法,这个可以给一个事件定义多个监听器 - [gte IE 9]
element.removeEventListener(xx,funcName)[gte IE 9]
element.attachEvent(xx, funcName)Only [IE]+
注意要带"on"
element.detachEvent(xx, funcName)Only [IE]+
注意要带"on"
Level 1:
document.anchors
document.applets
document.body
document.cookie
document.domain
document.forms
document.images
document.links - area/ a带href
document.referrer
document.title
document.URL
Level 3:
document.baseURI
document.doctype
document.documentElement - html
document.documentMode
document.documentURI
document.domConfig
document.embeds
document.head
document.implementation
document.inputEncoding
document.lastModified
document.readyState
document.scripts
document.strictErrorChecking
document.location - 与window.location指向同一个Location对象
attributes+
如该节点为Element,以NameNodeMap形式返回该元素属性
nodeName
nodeType
nodeValue
parentNode
childNodes+
以NodeList形式返回
firstChild
lastChild
nextSibling
previousSibling
Node.ELEMENT_NODE - 1
Node.TEXT_NODE - 3
Node.DOCUMENT_NODE - 9
Node.DOCUMENT_FRAGMENT_NODE - 11
Node.ATTRIBUTE_NODE - 2
Node.COMMENT_NODE - 8
一个Node不包括它里面的文字,若要获取文字:innerHTML或者firstChild.nodeValue
TextNode的NodeValue是它本身
nodeName约等于tagName,特别地:文字#text,#document,attributeNode
nodeType:Element(1),Attribute(2),Text(3),Comment(8),Document(9)
由于历史原因document.id/ document.forms[images/links].id可以获取元素
NodeList和ObjectCollections具有实时性,不会获取一次后就固定不动的
NodeList是个Array-like对象,可用NodeList.length获取个数
document object is your web page.
W3C DOM 包括 Core DOM,XML DOM,HTML DOM
ownerDocument - ?
因为有些CSS属性和JS的保留字冲突,各种浏览器有不同的获取方式,例如:style.styleFloat - [lte IE 8],style.cssFloat - [gte IE 9]和FF等
getAtribute("className")[lte IE 7]
getAttribute("class") - FF
getAttribute("htmlFor")[lte IE 7]
getAttribute("for") - FF
- 一些题外小笔记:
- IE支持[]和()访问,FF支持[]访问,所以大家都用[]访问NodeList中的元素
- FF不支持给元素宽高直接赋数字值,导致大家在赋值给元素宽高时都要用这样的形式width=h+"px"
- [lte IE 8]getYear取到的是实际年份,现代浏览器获取到的是年份减去1990
JavaScript处理HTML DOM的更多相关文章
- 借助JavaScript中的Dom属性改变Html中Table边框的颜色
借助JavaScript中的Dom属性改变Html中Table边框的颜色 -------------------- <html> <head> <title>我是页 ...
- JavaScript 节点操作Dom属性和方法(转)
JavaScript 节点操作Dom属性和方法 一些常用的dom属性和方法,列出来作为手册用. 属性: 1.Attributes 存储节点的属性列表(只读) 2.childNodes 存储 ...
- javascript系列之DOM(一)
原文:javascript系列之DOM(一) DOM(document object moudle),文档对象模型.它是一个中立于语言的应用程序接口(API),允许程序访问并修改文档的结构,内容和样式 ...
- javascript系列之DOM(二)
原文:javascript系列之DOM(二) 原生DOM扩展 我们接着第一部分来说,上文提到了两种常规的DOM操作:创建文档片段和遍历元素节点.我们知道那些雨后春笋般的库,有很大一部分工作就是提供了一 ...
- javascript系列之DOM(三)---事件
原文:javascript系列之DOM(三)---事件 事件是javascript跳动的心脏,是DOM所有成分结合的万金油.当我们在WEB 上进行某些交互时,事件也就发生了.点击某些内容,鼠标经过特定 ...
- JQuery $ $.extend(),$.fn和$.fn.extend javaScript对象、DOM对象和jQuery对象及转换 工具方法(utility)
一.为什么jquery前面要写$ Javascript没有package的概念,而作者又希望所有jQuery相关的API都能通过一个全局性的对象来容纳. 名为jQuery的全局变量就是这样一个对象,不 ...
- javascript中获取dom元素的高度和宽度
javascript中获取dom元素高度和宽度的方法如下: 网页可见区域宽: document.body.clientWidth网页可见区域高: document.body.clientHeight网 ...
- JavaScript和HTML DOM的区别与联系
JavaScript和HTML DOM的区别与联系 区别: javascript JavaScript 是因特网上最流行的浏览器脚本语言.很容易使用!你一定会喜欢它的! JavaScript 被数百万 ...
- console.time 简单分析javascript动态加入Dom节点的性能
Bullshit 本来想每天都更新下博客的,可是近期要考试,还有就是自己还是停留在暗自窃喜中吧(这样的想法要改变). 事实上近期总在想.自己要怎么去管理自己的数据,每天的生活都是对自己的数据的增删查改 ...
随机推荐
- BeanUtils 以及BeanUtils.populate使用
Apache Jakarta Commons项目非常有用.我曾在许多不同的项目上或直接或间接地使用各种流行的commons组件.其中的一个强大的组件就是BeanUtils.我将说明如何使用BeanUt ...
- 认识Java数组(一)
特别想喜欢一个寓言故事: 噢,它明白了,河水既没有牛伯伯说的那么浅,也没有小松鼠说的那么深,只有自己亲自试过才知道!道听途说永远只能看到表面现象,只有亲自试过了,才知道它的深浅!!!!! 言归正传: ...
- php中数字和字母生成随机字符串
function strrand($len) { $arr = array( "0", "1", "2", "3", & ...
- [汇编语言]-第九章 在屏幕中间分别显示绿底红色,白底蓝色字符串"welcome to masm!"
;在屏幕中间分别显示绿色,绿底红色,白底蓝色字符串"welcome to masm!" assume cs:codesg,ds:datasg,ss:stacksg datasg s ...
- shell全备份脚本(借鉴别人的,在其基础上修复完善了bug)
#!/bin/bash # Shell script to backup MySql database # Last updated: Aug - MyUSER="root" # ...
- 1 起步-Pro Git---VCS比较、git基本原理、git配置
本地版本控制系统 集中化的版本控制系统 诸如 CVS,Subversion 以及 Perforce 等,都有一个单一的集中管理的服务器,保存所有文件的修订版本,而协同工作的人们都通过客户端连到这台服务 ...
- jquery实现导航栏鼠标点击后实行背景高亮,点击离开恢复(超级简单!!!!),jquery导航栏
1.header部分要引入Jquery <asp:Content ID="HeaderContent" runat="server" ContentPla ...
- QT多重继承的时候,要把QObject放在最前面,否则报错——C++认为人性本恶,默认都是私有的,这点和Delphi的世界观不一样
在买来的控件(没有源码)的基础上,想加入QObject的一些特性,不得不多继承: class MyProgress : public CProgress, public QObject 但总是报错: ...
- libevent evbuffer bug
今天发现 libevent 2.0.22 一个坑爹的bug,导致消息混乱.查找问题浪费一天,复现代码如下 #include <event2/buffer.h> #include <s ...
- [转]Geoserver实现WFS操作
From:http://liushaobo2005.blog.163.com/blog/static/253056702011541462372/ wfs是OGC的标准规范,主要用于提供对矢量地理数据 ...