首页
学习
活动
专区
圈层
工具
发布
首页
学习
活动
专区
圈层
工具
MCP广场
社区首页 >问答首页 >试图通过className获取元素似乎不起作用

试图通过className获取元素似乎不起作用
EN

Stack Overflow用户
提问于 2015-02-20 14:57:33
回答 2查看 6.6K关注 0票数 1

试图在HTML代码中注入动态年份。

getElementById可以很好地工作,但是getElementsByClassName似乎不起作用。

这是我的密码。

HTML

代码语言:javascript
运行
复制
<p>this year is <span class="year"></span></p>

JAVASCRIPT

代码语言:javascript
运行
复制
document.getElementsByClassName("year").innerHTML = new Date().getFullYear();

想知道我做错了什么。

EN

回答 2

Stack Overflow用户

回答已采纳

发布于 2015-02-20 14:58:27

使用此方法可以得到一个元素数组。要访问第一个元素,请编写以下内容:

代码语言:javascript
运行
复制
document.getElementsByClassName("year")[0].innerHTML = new Date().getFullYear();
票数 8
EN

Stack Overflow用户

发布于 2015-02-25 18:57:05

getElementsByClassName函数返回一个HTMLCollection对象。

可以使用与数组相同的语法访问集合中的每个元素:

代码语言:javascript
运行
复制
var yearCollection = document.getElementsByClassName("year");
yearCollection[0].innerHTML = new Date().getFullYear();

还可以使用querySelectorquerySelectorAll检索元素。

在我看来,使用querySelector的结果更具可读性:

代码语言:javascript
运行
复制
document.querySelector(".year").innerHTML = new Date().getFullYear();

querySelectorquerySelectorAll使用CSS选择器来获取DOM中的元素。

有关perf的快速比较,请参见:http://jsperf.com/selection-amdg2-azfne65

票数 1
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/28631930

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档