首页 web前端 html教程 HTML5 特性之 Mutation Observer_html/css_WEB-ITnose

HTML5 特性之 Mutation Observer_html/css_WEB-ITnose

Jun 21, 2016 am 08:46 AM

前言

上周某业务 App 中页面被劫持,看到这个我想到两个分享,一个是第一届 FEDay 上石玉磊 @ 腾讯有分享如何做的问题,第二个是在朋友圈看到 @ 糖饼分享的方案。 结合这两个有了今天的这个 API 的分享。感谢 @ 草根程序猿 的博文。文末有疑惑解答!!

正文从这开始~

1 、概述

Mutation Observer (变动观察器)是监视 DOM 变动的接口。当 DOM 对象树发生任何变动时, Mutation Observer 会得到通知。

要概念上,它很接近事件。可以理解为,当 DOM 发生变动会触发 Mutation Observer 事件。但是,它与事件有一个本质不同:事件是同步触发,也就是说 DOM 发生变动立刻会触发相应的事件; Mutation Observer 则是异步触发, DOM 发生变动以后,并不会马上触发,而是要等到当前所有 DOM 操作都结束后才触发。

这样设计是为了应付 DOM 变动频繁的情况。举例来说,如果在文档中连续插入 1000 个段落( p 元素),会连续触发 1000 个插入事件,执行每个事件的回调函数,这很可能造成浏览器的卡顿;而 Mutation Observer 完全不同,只在 1000 个段落都插入结束后才会触发,而且只触发一次。

注:在控制台可看到 log

Mutation Observer 有以下特点:

  • 它等待所有脚本任务完成后,才会运行,即采用异步方式

  • 它把 DOM 变动记录封装成一个数组进行处理,而不是一条条地个别处理 DOM 变动。

  • 它即可以观察发生在 DOM 节点的所有变动,也可以观察某一类变动

目前, Firefox(14+) 、 Chrome(26+) 、 Opera(15+) 、 IE(11+) 和 Safari(6.1+) 支持这个 API 。 Safari 6.0 和 Chrome 18-25 使用这个 API 的时候,需要加上 WebKit 前缀( WebKitMutationObserver )。可以使用下面的表达式检查浏览器是否支持这个 API 。

2 、使用方法

首先,使用 MutationObserver 构造函数,新建一个实例,同时指定这个实例的回调函数。

2.1 observer 方法

observer 方法指定所要观察的 DOM 元素,以及要观察的特定变动。

上面代码首先指定,所要观察的 DOM 元素提 article ,然后指定所要观察的变动是子元素的变动和属性变动。最后,将这两个限定条件作为参数,传入 observer 对象的 observer 方法。

MutationObserver 所观察的 DOM 变动(即上面代码的 option 对象),包含以下类型:

  • childList :子元素的变动

  • attributes :属性的变动

  • characterData :节点内容或节点文本的变动

  • subtree :所有下属节点(包括子节点和子节点的子节点)的变动

想要观察哪一种变动类型,就在 option 对象中指定它的值为 true 。需要注意的是,不能单独观察 subtree 变动,必须同时指定 childList 、 attributes 和 characterData 中的一种或多种。

除了变动类型, option 对象还可以设定以下属性:

  • attributeOldValue :值为 true 或者为 false 。如果为 true ,则表示需要记录变动前的属性值。

  • characterDataOldValue :值为 true 或者为 false 。如果为 true ,则表示需要记录变动前的数据值。

  • attributesFilter :值为一个数组,表示需要观察的特定属性(比如 ['class', 'str'] )。

2.2 disconnect 方法和 takeRecord 方法

disconnect 方法用来停止观察。发生相应变动时,不再调用回调函数。

takeRecord 方法用来清除变动记录,即不再处理未处理的变动。

2.3 MutationRecord 对象

DOM 对象每次发生变化,就会生成一条变动记录。这个变动记录对应一个 MutationRecord 对象,该对象包含了与变动相关的所有信息。 Mutation Observer 进行处理的一个个变动对象所组成的数组。

MutationRecord 对象包含了 DOM 的相关信息,有如下属性:

  • type: 观察的变动类型( attribute 、 characterData 或者 childList )。

  • target: 发生变动的 DOM 对象。

  • addedNodes: 新增的 DOM 对象。

  • removeNodes: 删除的 DOM 对象。

  • previousSibling: 前一个同级的 DOM 对象,如果没有则返回 null 。

  • nextSibling: 下一个同级的 DOM 对象,如果没有就返回 null 。

  • attributeName: 发生变动的属性。如果设置了 attributeFilter ,则只返回预先指定的属性。

  • oldValue: 变动前的值。这个属性只对 attribute 和 characterData 变动有效,如果发生 childList 变动,则返回 null 。

3 、实例

3.1 子元素的变动

下面的例子说明如果读取变动记录。

上面代码的观察器,观察 body 元素的所有下级元素( childList 表示观察子元素, subtree 表示观察子元素的下级元素)的变动。回调函数会在控制台显示所有变动的类型和目标元素。

3.2 、属性的变动

下面的例子说明如何追踪属性的变动。

上面代码先设定追踪属性变动( 'attributes':true ),然后设定记录变动前的值。实际发生变动时,会将变动前的值显示在控制台。

后语

更多可以参考 MDN : https://developer.mozilla.org/zh-CN/docs/Web/API/MutationObserver

关于本文

作者: @ 草根程序员

原文链接: http://www.cnblogs.com/jscode/p/3600060.html

昨天早读君有发了三个问题,@豆腐童鞋针对@小幸运问题进行解答,非常感谢。

@ 小幸运。: 我是在公司实习了两个月了,但是由于刚出学校,技术,经验都不是很好,慢慢喜欢的前端都觉得有些不太喜欢了。这种情况怎么办?

@豆腐( 华农大学、百度前端实习生 ):实习两个月的也有时有这样想法的 +1 。其实这种情况我自己总结了一下觉得大概有两点。一是刚进公司的新奇感消失了,每天都在做业务久而久之就觉得无聊不想做,另一个可能是在业务上遇到自己太多不会的,对自己的技术水平产生了怀疑,想放弃实习回去进一步进修。 我自己的解决办法是周末的时候做一些自己想做的事情,抛下业务去寻找前端的乐趣。比如画一个动画,看看博客分享然后对里面的疑问实践一下,找一些面试题笔试题看看有什么不会的去学习下 … 然后内心给自己打一针鸡血,告诉自己要奋斗要努力要好好打代码,这样大概周一上班的时候就会想,好!这周要好好奋斗!嗯

本站声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

热AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover

AI Clothes Remover

用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

记事本++7.3.1

记事本++7.3.1

好用且免费的代码编辑器

SublimeText3汉化版

SublimeText3汉化版

中文版,非常好用

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

Dreamweaver CS6

Dreamweaver CS6

视觉化网页开发工具

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

热门话题

Java教程
1662
14
CakePHP 教程
1418
52
Laravel 教程
1311
25
PHP教程
1261
29
C# 教程
1234
24
HTML容易为初学者学习吗? HTML容易为初学者学习吗? Apr 07, 2025 am 12:11 AM

HTML适合初学者学习,因为它简单易学且能快速看到成果。1)HTML的学习曲线平缓,易于上手。2)只需掌握基本标签即可开始创建网页。3)灵活性高,可与CSS和JavaScript结合使用。4)丰富的学习资源和现代工具支持学习过程。

了解HTML,CSS和JavaScript:初学者指南 了解HTML,CSS和JavaScript:初学者指南 Apr 12, 2025 am 12:02 AM

WebDevelovermentReliesonHtml,CSS和JavaScript:1)HTMLStructuresContent,2)CSSStyleSIT和3)JavaScriptAddSstractivity,形成thebasisofmodernWebemodernWebExexperiences。

HTML,CSS和JavaScript的角色:核心职责 HTML,CSS和JavaScript的角色:核心职责 Apr 08, 2025 pm 07:05 PM

HTML定义网页结构,CSS负责样式和布局,JavaScript赋予动态交互。三者在网页开发中各司其职,共同构建丰富多彩的网站。

HTML,CSS和JavaScript:Web开发人员的基本工具 HTML,CSS和JavaScript:Web开发人员的基本工具 Apr 09, 2025 am 12:12 AM

HTML、CSS和JavaScript是Web开发的三大支柱。1.HTML定义网页结构,使用标签如、等。2.CSS控制网页样式,使用选择器和属性如color、font-size等。3.JavaScript实现动态效果和交互,通过事件监听和DOM操作。

HTML:结构,CSS:样式,JavaScript:行为 HTML:结构,CSS:样式,JavaScript:行为 Apr 18, 2025 am 12:09 AM

HTML、CSS和JavaScript在Web开发中的作用分别是:1.HTML定义网页结构,2.CSS控制网页样式,3.JavaScript添加动态行为。它们共同构建了现代网站的框架、美观和交互性。

HTML的未来:网络设计的发展和趋势 HTML的未来:网络设计的发展和趋势 Apr 17, 2025 am 12:12 AM

HTML的未来充满了无限可能。1)新功能和标准将包括更多的语义化标签和WebComponents的普及。2)网页设计趋势将继续向响应式和无障碍设计发展。3)性能优化将通过响应式图片加载和延迟加载技术提升用户体验。

HTML与CSS vs. JavaScript:比较概述 HTML与CSS vs. JavaScript:比较概述 Apr 16, 2025 am 12:04 AM

HTML、CSS和JavaScript在网页开发中的角色分别是:HTML负责内容结构,CSS负责样式,JavaScript负责动态行为。1.HTML通过标签定义网页结构和内容,确保语义化。2.CSS通过选择器和属性控制网页样式,使其美观易读。3.JavaScript通过脚本控制网页行为,实现动态和交互功能。

HTML,CSS和JavaScript的未来:网络开发趋势 HTML,CSS和JavaScript的未来:网络开发趋势 Apr 19, 2025 am 12:02 AM

HTML的未来趋势是语义化和Web组件,CSS的未来趋势是CSS-in-JS和CSSHoudini,JavaScript的未来趋势是WebAssembly和Serverless。1.HTML的语义化提高可访问性和SEO效果,Web组件提升开发效率但需注意浏览器兼容性。2.CSS-in-JS增强样式管理灵活性但可能增大文件体积,CSSHoudini允许直接操作CSS渲染。3.WebAssembly优化浏览器应用性能但学习曲线陡,Serverless简化开发但需优化冷启动问题。

See all articles