--- title: MutationObserverInit.attributeFilter slug: conflicting/Web/API/MutationObserver/observe tags: - API - DOM - DOM WHATWG - Mutation Observers - MutationObserverInit - 变化 - 属性 - 属性过滤器 - 监听器 translation_of: Web/API/MutationObserverInit/attributeFilter original_slug: Web/API/MutationObserverInit/attributeFilter ---
{{domxref("MutationObserverInit")}} 字典的可选属性 attributeFilter
是一个字符串数组,用于指定要监听变化的属性名称。 如果指定了该属性,则 {{domxref("MutationObserverInit.attributes", "attributes")}} 无论是否为 true
,属性监听都将启用。
如果属性 {{domxref("MutationObserverInit.attributes", "attributes")}} 设置为 true
,但options对象中未包含 attributeFilter
,则所有属性的变化都会被监听。
var options = { attributeFilter: [ "list", "of", "attribute", "names" ] }
{{domxref("DOMString")}}数组, 每项指定一个要监听其变化的属性名称,没有默认值。
当使用构造函数{{domxref("MutationObserver.MutationObserver", "MutationObserver()")}}创建MutationObserver
对象时,如果options对象中存在该属性,则无论{{domxref("MutationObserverInit.attributes", "attributes")}}是否为true
,都将启用属性监听。
在本示例中,设置了一个变化监听器来监听用于显示聊天室用户名的子树中所有元素的status
和username
属性的变化。这样就可以反应用户昵称或状态的更改, 例如,可以将用户标记为离开或离线。
function callback(mutationList) { mutationList.forEach(function(mutation) { switch(mutation.type) { case "attributes": switch(mutation.attributeName) { case "status": userStatusChanged(mutation.target.username, mutation.target.status); break; case "username": usernameChanged(mutation.oldValue, mutation.target.username); break; } break; } }); } var userListElement = document.querySelector("#userlist"); var observer = new MutationObserver(callback); observer.observe(userListElement, { attributeFilter: [ "status", "username" ], attributeOldValue: true, subtree: true });
callback()
函数将在监听器启动时传给{{domxref("MutationObserver.observe", "observe()")}}方法,用来检查{{domxref("MutationRecord")}}对象的每一项。对于代表属性更改的任何项(可以通过{{domxref("MutationRecord.type")}}的值为“ attributes
”的值来检测),我们使用通过{{domxref("MutationRecord.attributeName")}}获得的属性名称来识别发生的更改的类型,然后将其分派给适当的处理函数。
请注意,在查找本地用户数组时可以使用{{domxref("MutationRecord.oldValue")}}来获取username
的上一个值。
当observe()被调用时, options对象中指定了attributeFilter
和{{domxref("MutationObserverInit.subtree", "subtree")}},所以id为“userlist
”的元素的所有子树的所有节点的属性值都会被监听。{{domxref("MutationObserverInit.attributeOldValue", "attributeOldValue")}}被设置为true
,因为我们希望在监听到值变化时可以获取到上一个值。
规范 | 状态 | 说明 |
---|---|---|
{{SpecName('DOM WHATWG', '#dom-mutationobserverinit-attributefilter', 'MutationObserverInit: attributeFilter')}} | {{ Spec2('DOM WHATWG') }} |
{{Compat("api.MutationObserverInit.attributeFilter")}}