DOM

DOM是什么

DOM(document object model)文档对象模型。
浏览器根据DOM模型,将结构化文档如(HTML和XML)解析成有结构的节点树。
可以给这些节点添加CSS来进行渲染
所有的节点都有对外的接口。Javascript通过DOM这个接口来操作网页

节点

DOM的最小组成单位,构成DOM树的最小基本单位

节点类型

Document //整个文档的顶层节点
DocumentType //doctype 标签
Element // 由HTML标签构成的节点
Atribute //标签元素的属性构成
text //由HTML标签里的文本,和标签之间的文本构成
comment //注释节点
fragment //不在节点树上,可以包含节点片段

fragment节点

//语法
document.createDocumentFragment

DocumentFragment是DOM节点,但不是主DOM树的一部分。在DOM树中,DocumentFragment会被其拥有的孩子替代,插入DocumentFragment时不会引起页面回流,会有性能优化的作用

属性

所有节点对象都是浏览器内置的NODE对象的实例,继承了Node对象的属性和方法

节点属性

以下如果没有的话,都返回null
node类:返回包括文本节点(标签之间的空格也是文本节点)注释节点
Node.nodeName  和 Node.nodeType
返回节点名称和节点类型
Node.baseURI
返回当前网址路径
node.nextSibling  
node.previousSibling
node.parentNode
node.childNodes  //可以通过后面加序号的方式访问子节点。node.childNodes[0]
node.firstChild
node.lastChild
Node.appendChild()//接受一个节点对象做为参数,作为最后一个子节点,将其插入到当前节点,如果参数节点是DOM中已经存在的节点,此方法会将其从原来的位置移动到新位置
Node.hasChildNodes()//不必传递参数,返回true 或 false 判断是否有子节点
Node.cloneNode()// 参数为true时,克隆元素里面的内容
Node.insertBefore()
//返回被插入的新节点
Node.removeChild()接受一个子节点作为参数,用于从当前节点移除该子节点
//回被移除的子节点
Node.replaceChild()它接受两个参数,第一个参数是用来替换的新节点,第二个参数将要被替换走的子节点
//返回被替换走的那个节点
Node.contains()//Node.contains方法接受一个节点作为参数,返回一个布尔值,表示参数节点是否为当前节点的后代节点
对应的有:
Element.nextElementSibling  
Element.previousElementSibling
Element.parentElement
Element.firstElementChild
Element.lastElementChild

Element节点

document.documentElement // html元素
document.body //body元素
Element.attributes //返回属性集合的类数组对象
Element.id //可读写
Element.src
Element.href
Element.title
Element.tagName //只读
Element.innerHTML
Element.outerHTML
Element.className //返回字符串
Element.classList //返回类数组对象
Element.classList对象的方法:
    add():增加一个class。
    remove():移除一个class。
    contains():检查当前元素是否包含某个class。
    toggle():将某个class移入或移出当前元素。
    item():返回指定索引位置的class。
    toString():将class的列表转为字符串。
//生成节点
document.createElement()
document.createTextNode()
//插入节点
Node.appendChild()
Node.insertBefore()
//删除节点
Element.remove()
//操作属性
Element.getAttribute()
Element.setAttribute()
Element.hasAttribute()
Element.removeAttribute()
//style对象
ele.style.background='yellow' //等价于
ele.setAttribute('style','background:yellow')

获取Element的属性

方法一:直接用.
ele.属性名(获取class需要 .className)
方法二:
ele.getAttribute(属性名)

在容器的开头或者结尾插入元素

var ct = document.querySelector('.ct');
var li=document.createElement('li');
li.innerText='内容';
ct.insertBefore(li,ct.firstElementChild)  //开头插入
// 或者 
ct.insertBefore(li,ct.firstChild)
ct.appendChild(li)  //结尾插入

盒状模型相关属性

  • 获取滚动条距离
Element.scrollTop  Element.scrollLeft
可读写 ,常用的是
document.body.scrollLeft
document.body.scrollTop
JQ写法
$(window).scrollTop()
$('body').scrollTop()
  • 获取元素的宽高
clientWidth   scrollWidth   offsetWidth 
以下三种方法都包括内容区和padding
Element.clientHeight   Element.clientWidth
不包括border,margin,溢出部分      
\                      
Element.scrollHeight  Element.scrollWidth
包括溢出部分。
不包括border,margin
\
Element.offsetHeight,Element.offsetWidth
包括内容区Padding,溢出部分 Border,不包括margin
  • 获取当前视窗的宽高
window.innerWidth// 浏览器视口(viewport)宽度(单位:像素),如果存在垂直滚动条则包括它
document.documentElement.clientWidth // 不包括滚动条
document.documentElement.clientHeight // 不包括滚动条
JQ写法
$(window).height()
  • 获取网页的总宽高
// 网页总高度
document.documentElement.offsetHeight
document.documentElement.scrollHeight
document.body.offsetHeight
document.body.scrollHeight
\
// 网页总宽度
document.documentElement.offsetWidth
document.documentElement.scrollWidth
document.body.offsetWidth
document.body.scrollWidth
  • 获取元素的坐标
// 网页元素左上角的网页横坐标
Element.getBoundingClientRect().left + document.documentElement.scrollLeft
\
// 网页元素左上角的网页纵坐标
Element.getBoundingClientRect().top + document.documentElement.scrollTop
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 207,248评论 6 481
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 88,681评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 153,443评论 0 344
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 55,475评论 1 279
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 64,458评论 5 374
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,185评论 1 284
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,451评论 3 401
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,112评论 0 261
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 43,609评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,083评论 2 325
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,163评论 1 334
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,803评论 4 323
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,357评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,357评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,590评论 1 261
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,636评论 2 355
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,925评论 2 344

推荐阅读更多精彩内容