如何在 Javascript 中获取 foreach 元素的类名?

发布于 2025-01-17 13:18:58 字数 216 浏览 5 评论 0原文

const dropdownmenu = document.querySelector(".dropdownmenu")

dropdownmenu.forEach(element => {
    
    console.log(element.classname)
    
});

问题是如何在 Javascript 中获取 foreach 元素的类名?

const dropdownmenu = document.querySelector(".dropdownmenu")

dropdownmenu.forEach(element => {
    
    console.log(element.classname)
    
});

Question is How can i get classname of element of foreach in Javascript ?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(1

凉薄对峙 2025-01-24 13:18:58

两个问题:

  1. document.querySelector 仅选择一个元素 - 与指定选择器匹配的第一个元素。您应该使用 document.querySelectorAll 来获取元素数组。
  2. .classname 应该是驼峰式 -> .className

我假设您正在尝试获取下拉菜单内的元素。您可以这样做:

<ul class="dropdown-menu">
    <li class="item">item1</li>
    <li class="item">item2</li>
    <li class="item">item3</li>
</ul>

<script>
    const menu = document.querySelector('.dropdown-menu')

    for (const elem of menu.querySelectorAll('.item')) {
        console.log(elem.className);
    }
</script>

如果您尝试侦听下拉菜单上所有项目的事件,请尝试将事件侦听器放在父级上,并使用 e.target 来定位单击的子级。

<p>Click the items</p>
<ul class="dropdown-menu">
    <li class="item">item1</li>
    <li class="item">item2</li>
    <li class="item">item3</li>
</ul>

<script>
    const menu = document.querySelector('.dropdown-menu');

    menu.addEventListener('click', (e) => {
        console.log(e.target.textContent);
    });
</script>

Two issues:

  1. document.querySelector only selects one element - the first element that matches the specified selector. You should use document.querySelectorAll to grab an array of elements.
  2. .classname should be camelcased -> .className

I'm assuming you are trying to grab the elements inside of the dropdown menu. Here's how you'd do that:

<ul class="dropdown-menu">
    <li class="item">item1</li>
    <li class="item">item2</li>
    <li class="item">item3</li>
</ul>

<script>
    const menu = document.querySelector('.dropdown-menu')

    for (const elem of menu.querySelectorAll('.item')) {
        console.log(elem.className);
    }
</script>

If you're trying to listen for events on the dropdown menu for all of the items, try putting the event listener right on the parent and using e.target to target the clicked child.

<p>Click the items</p>
<ul class="dropdown-menu">
    <li class="item">item1</li>
    <li class="item">item2</li>
    <li class="item">item3</li>
</ul>

<script>
    const menu = document.querySelector('.dropdown-menu');

    menu.addEventListener('click', (e) => {
        console.log(e.target.textContent);
    });
</script>

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文