作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我想创建一个脚本,单击后将删除两个 li 项目上的类,并将类添加到另一个 li 项目。我已经使用了 .className 方法,但它只能部分工作。
<div class="collapse navbar-collapse" id="bs-example-navbar-collapse-1">
<ul class="nav navbar-nav navbar-right">
<li class="tbh lista">
<a href="#"><img src="images/facebook.png"></a>
</li>
<li class="tbh lista">
<a href="#"><img src="images/mail.png"></a>
</li>
<li class="lista">
<a href="#" onclick="changeClass()" id="phone"><img src="images/phone.png"></a>
</li>
<li class="lista hidden">
<p>text</p>
</li>
</ul>
</div>
这是脚本:
function changeClass(){
var elements = document.getElementsByClassName('tbh');
for (var i = 0, len = elements.length; i <=len; i++) {
elements[i].className='hidden';
console.log('aaa');
}
}
我单击 li 项目一次后,只有一个 li 项目消失,并且出现错误。我必须单击它两次才能正常运行。我找不到错误。这些显示在 console.log 中:aaa
未捕获的类型错误:无法设置未定义的属性“className”
最佳答案
这是因为 document.getElementsByClassName
返回 HTMLCollection 而不是 Array。所以改变你的字符串
var elements = document.getElementsByClassName('tbh');
至
var elements = Array.from(document.getElementsByClassName('tbh'));
关于JavaScript 只能部分工作,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/40201015/
有一条(相对)众所周知的 Perl 公理:“只有 Perl 可以解析 Perl”。我想知道 Perl 6 是否仍然如此? 扩大讨论...考虑到 PyPy 最近的更新,我想到了这个问题。 Perl 独特
这是设置。在上一个问题中,我发现我可以通过子组件中的状态传递对象属性,然后使用 componentDidUpdate 获取该对象属性。在这种情况下,状态和属性都称为到达。 这是基本代码... expo
我运行的是 10.5.2 社区版。我已经标记了 源/主要/资源 作为源目录。我可以右键单击并“编译”某些文件,据我所知,这意味着 IDE 将文件复制到与发送类文件的“com.mydomain.pack
我是一名优秀的程序员,十分优秀!