作者热门文章
- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我一直在学习 JavaScript,我遇到了这个:
HTML:
<ul id="nav">
<li><a href="/" id="home">Home</a></li>
<li><a href="/about" id="about">About Us</a></li>
<li><a href="/contact" id="contact">Contact Us</a></li>
</ul>
JavaScript:
document.getElementById("about").parentNode.setAttribute("class", "active");
document.getElementById("about").parentNode.previousSibling.setAttribute("class", "previous");
document.getElementById("about").parentNode.nextSibling.setAttribute("class", "next");
但是每次我运行这段代码,我都会得到一个“TypeError”唯一似乎有效的是 document.getElementById("about").parentNode.setAttribute
。
这是正确的还是那些奇怪的东西最终无缘无故地不起作用?
最佳答案
问题是由每个 <li>
之间的换行符引起的节点。使用此 HTML 将起作用:
<ul id="nav">
<li><a href="/" id="home">Home</a></li><li><a href="/about" id="about">About Us</a></li><li><a href="/contact" id="contact">Contact Us</a></li>
</ul>
在换行完好无损的情况下,previousSibling
和 nextSibling
是 textNode
包含换行符。
我建议使用 jQuery相反——使用 jQuery 选择器可以避免这些类型的问题。
关于javascript - 这段代码对不对?我觉得应该是,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/14097120/
我是一名优秀的程序员,十分优秀!