我试图得到class = 4的子span。下面是一个示例元素:
<div id="test">
<span class="one"></span>
<span class="two"></span>
<span class="three"></span>
<span class="four"></span>
</div>
我可用的工具是JS和YUI2。我可以这样做:
doc = document.getElementById('test');
notes = doc.getElementsByClassName('four');
//or
doc = YAHOO.util.Dom.get('#test');
notes = doc.getElementsByClassName('four');
这些在IE中不起作用。我得到一个错误,对象(doc)不支持此方法或属性(getElementsByClassName)。我已经尝试了几个跨浏览器实现getElementsByClassName的例子,但我不能让他们工作,仍然得到了这个错误。
我认为我需要的是一个跨浏览器getElementsByClassName或我需要使用doc.getElementsByTagName('span')和循环,直到我找到类4。但我不知道该怎么做。
我知道这个问题已经存在几年了,也有一些答案,但我想我会补充我的解决方案,以防它能帮助到任何人。它与user2795540给出的答案相同,并且涉及一个数组迭代器。
如果你只是想要得到第一个有四个类的子类,那么你可以使用find array迭代器。你的浏览器需要能够支持ES6,或者你可以使用Babel将你的JS编译成所有浏览器都支持的东西。没有polyfill, IE将不支持此功能。
使用你在问题中提供的相同细节,它可以是这样的:
const parentNode = document.getElementById('test');
const childNode = Array.from(parentNode.childNodes).find(({ className }) => className === 'four');
上面的解决方案将返回您想要的目标节点,并将其存储在childNode变量中。
你可以在https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Array/find上找到更多关于find数组迭代器的信息
我相信这能最好地回答你的问题
document.querySelector('* > span.four')
这将匹配它发现的第一个子元素(任何父元素),它是一个span,并且也有一个类“4”设置给它
但是,由于在您的示例中还有一个可以通过id检索的父元素,您也可以使用this代替
document.querySelector('#test > span.four')
如果您有一个父元素保存在一个变量中,就像您的例子中那样,并且您希望搜索该元素的子树,使用:scope(正如Billizzard已经提到的)可能是您的最佳选择
doc.querySelector(':scope > span.four');
额外提示:如果您要查找的子元素不是直接的子后代元素,而是在子树的更远位置,您实际上可以像这样省略>
document.querySelector('#test span.four')