关于DOM的知识整理(2)----DOM扩展


这个部分主要总结一下对DOM的两个主要的扩展SelectorAPI和HTML5


选择符API

querySelector()方法

该方法接收一个CSS选择符,返回与该模式匹配的第一个元素,如果没有找到匹配的元素,则返回null

querySelectorAll()方法

querySelectorAll()方法接收的参数querySelector()方法一样,都是一个CSS选择符,但返回的是所有匹配的元素的类似NodeList的集合,但是其底层实现类似于一组元素的快照,而非不断对完档进行搜索的动态查询,因此可以避免引起大多数性能问题. 如果没有找到匹配的元素,NodeList就是空的.

matchesSelector()方法

接收CSS选择符作为参数,如果调用元素与该选择符匹配,则返回true,反之,返回false

元素遍历

由于使用childNodes和firstChild等属性时,会考虑到文本节点,导致和预想结果不一致,为了弥补这一差异,Element Traversal规范新定义了一组属性

childElementCount:

返回子元素(不包括文本节点和注释)的个数

firstElementChild:

firstChild的元素版

lastElementChild:

lastChild的元素版

previousElementSibling:

previousSibling的元素版

nextElementSibling:

nextSibling的元素版

HTML5

getElementsByClassName()

其实HTML5添加的getElementsByClassName()实现的功能用querySelectorAll()也能实现,不过其返回的对象时NodeList对象,而不是快照,因此存在着性能问题,若不没有实时性的需要,那么建议使用querySelectorAll()来代替getElementsByClassName()

classList属性

HTML5新增一种操作类名的方式,为所有元素添加classList属性,是新集合类型DOMTokenList的实例,与其他DOM集合类似,也有length属性,另外还有以下方法

  • add(value) : 将给定的字符串值添加到列表中
  • contains(value) : 表示列表中是否存在给定的值,存在则返回true,反之返回false
  • remove(value) :从列表中删除给定的字符串
  • toggle(value) : 如果列表中已经存在给定的值,则删除,反之则添加

注意:classList属性虽然好用,但是兼容性不是很好,所以使用前根据需要是否要准备跨浏览器方案

焦点管理

document.activeElement

这个属性始终会引用DOM中当前获得了焦点的元素,默认情况下,文档刚刚加载完成后,document.activeElement中爆粗你的事document.body元素的引用

document.hasFocus()

这个方法可用于确定文档是否获得了焦点,知道用户是不是正在与页面交互

HTMLDocument的变化

document.readyState

有两个可能值:
①loading ,正在加载文档;
②complete ,已经加载完文档

document.head

引用文档的<head>元素

字符集属性

主要指document.charset,获取当前文档中实际使用的字符集,以及defalutCharset表示当前文档默认的字符集应该是什么

自定义数据属性

HTML5规定可以为元素添加非标准的属性,但要添加前缀data-,目的是为元素提供与渲染无关的信息或者提供语义信息.
添加了自定义属性之后,可以通过元素的dataset属性来访问自定义属性的值,每个data-name形式的属性都会有一个对应的属性,只不过属性名没有data-前缀

插入标记

innerHTML属性

在读模式下,innerHTML返回与调用元素的所有子节点对应的HTML标记
在写模式下,innerHTML会根据制定的值创建新的DOM树,然后用这个DOM树完全替换元素原先的所有子节点

outerHTML属性

在读模式下,outerHTML返回调用它的元素及其所有子节点的HTML标签
在写模式下,会根据特定的HTML字符串创建新的DOM字数,然后替换调用元素

insertAdjacentHTML()方法

接收两个参数:①插入位置②要插入的HTML文本
第一个参数从下面选取

  • "beforebegin" 当前元素之前插入
  • "afterbegin" 插入到当前元素作为第一个子元素
  • "beforeend" 插入到当前元素作为最后一个子元素
  • "afterend" 当前元素之后插入

scrpllIntoView()方法

scrollIntoView()可以在所有HTML元素上调用,通过滚动浏览器窗口或某个容器元素,调用元素就可以出现在视口中,如果传入true作为参数或不传入参数,则窗口滚动之后会让调用元素的顶部与视口顶部尽可能平齐,若传入false为参数,则调用元素会尽可能全部出现在视口中,顶部不一定平齐

children属性

由于IE9之前版本与其他浏览器在处理文本节点中的空白符有差异,所以添加children属性,只包含元素中同样还是元素的子节点,除此之外与childNodes没有区别.

contains()方法

可以通过contains知道某个节点是不是另一个节点的后代,调用contains()方法的应该是祖先节点,接收要检测的后代节点作为参数,如果被检测的节点是后代节点,则该方法返回true,否则返回false

插入文本

innerText属性

通过innerText属性可以操作元素中包含的所有文本,通过innerText读取值时,它会按照由浅入深的顺序,将子文档树种的所有文本拼接起来,在通过innerText写入值时,结果会删除元素的所有子节点,,插入包含相应文本值的文本节点

outerText属性

在作用范围上扩大到了包含调用他的节点之外,与innerText无区别


以上是参考高程3的总结内容.

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,686评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,668评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,160评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,736评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,847评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,043评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,129评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,872评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,318评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,645评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,777评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,861评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,589评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,687评论 2 351

推荐阅读更多精彩内容