javascript – DOM4:不推荐使用的属性和方法,这是什么意思?

“Warning: In DOM Core 1,2 and 3,Attr inherited from Node. This is no longer the case in DOM4. In order to bring the implementation of Attr up to specification,work is underway to change it to no longer inherit from Node . You should not be using any Node properties or methods on Attr objects. Starting in Gecko 7.0 (Firefox 7.0 / Thunderbird 7.0 / SeaMonkey 2.4),the ones that are going to be removed output warning messages to the console. You should revise your code accordingly. See Deprecated properties and methods for a complete list.”

向下滚动页面,我们可以看到nodeName和NodeValue的替换,使用Attr.name和Attr.value.

https://developer.mozilla.org/en/DOM/Attr#Deprecated_properties_and_methods

它对于属性或childNodes等其他方法意味着什么?
该参考文献称它已被弃用,但它们没有给予任何替代!

它已被弃用于属性,但它也适用于Node吗?

Attr对象:http://www.w3schools.com/jsref/dom_obj_attr.asp

编辑:对于Attributes(Attr),只能弃用nodeValue,因为Attr将不再在DOM Level 4中从Node继承:

这是一个帮助我理解的简单示例:

<div id="myAttribute">myTextNode</div>

var myDiv = document.getElementById("myAttribute");

// If you want to get "myAttribute" from div tag

alert(myDiv.attributes[0].value);
// Correct way to get value of an attribute (displays "myAttribute")
alert(myDiv.attributes[0].nodeValue);
// Working too but deprecated method for Attr since it doesn't inherit from Node in DOM4 (.nodeValue is specific to a Node,not an Attribute)

// If you want to get "myTextNode" from div tag

alert(myDiv.childNodes[0].value);
// Not working since .value is specific to an attribute,not a Node (displays "undefined")
alert(myDiv.childNodes[0].nodeValue);
// Working,.nodeValue is the correct way to get the value of a Node,it will not be deprecated for Nodes! (displays "myTextNode")

也许这会在访问属性/节点时避免与其他人混淆:)

解决方法

他们所说的是Attr实例的对象(例如 Element.getAttributeNode()返回的对象),曾经拥有从Node继承的属性.

但是,因为在DOM4中不是这种情况,所以他们试图删除这种继承.因此,当您现在获得Attr对象的实例时,the deprecated list中列出的属性将按其记录的方式运行.

一个很大的问题:对于一个属性它是否已被弃用,但它是否也适用于Node?:不,它们不会被弃用.您可以在it’s own文档页面中看到Node具有的属性列表.

无论如何,Attr对象使用不多(永远?);你确定这关心你吗?

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...