为了账号安全,请及时绑定邮箱和手机立即绑定

我可以使用两个 id 来获取一个元素吗?

我可以使用两个 id 来获取一个元素吗?

慕森王 2023-09-18 15:53:44
这是我的代码:<div id='layer1'>    <div id='a'>    <div id='b'><div id='layer2'>    <div id='a'>    <div id='b'><div id='layer3'>    <div id='a'>    <div id='b'>我想尝试获取layer1的元素[a]。我可以使用纯 javascript 而不使用 jquery 和其他东西来做到这一点吗?
查看完整描述

3 回答

?
至尊宝的传说

TA贡献1789条经验 获得超10个赞

ID 唯一标识页面上的单个元素。您描述的行为更像是 ID 内的“类”:

document.querySelector("#counter-for-drinks .up-arrow")

所以如果你想要一个不同的up-arrow,那就是:

document.querySelector("#counter-for-burgers .up-arrow")

document.querySelector()与 jQuery 类似$(" ")。它还具有document.querySelectorAll()获取所有匹配元素的形式。


查看完整回答
反对 回复 2023-09-18
?
三国纷争

TA贡献1804条经验 获得超7个赞

您的 HTML 缺少结束标签。另外,您应该使用class而不是id.


<div id='layer1'>

  <div class='a'></div>

  <div class='b'></div>      

</div>

<div id='layer2'>

  <div class='a'></div>

  <div class='b'></div>

</div>

<div id='layer3'>

  <div class='a'></div>

  <div class='b'></div>

</div>

您可以使用 javascript 来获取元素: document.querySelector("#layer1 .a")


查看完整回答
反对 回复 2023-09-18
?
慕森卡

TA贡献1806条经验 获得超8个赞

var firstA = document.querySelectorAll('#layer1 #a');

var nodeString = '';

if (firstA.length > 0) {

  for (var i = 0; i < firstA.length; i++) {

    nodeString = nodeString + firstA[i].innerText + '<br/>';

  }

}

document.getElementById('founded-nodes').innerHTML = nodeString;

#founded-nodes {

  color: brown;

}

<div id='layer1'>

  <div id='a'>layer1 aaa</div>

  <div id='b'>layer1 bbb</div>

</div>

<div id='layer2'>

  <div id='a'>layer2 aaa</div>

  <div id='b'>layer2 bbb</div>

</div>

<div id='layer3'>

  <div id='a'>layer3 aaa</div>

  <div id='b'>layer3 bbb</div>

</div>


<div id="founded-nodes"></div>

正如上面评论和答案中所说,必须在同一页面上使用单个 id,否则必须使用类。但如果你想实现这一点,你可以看一下代码。



查看完整回答
反对 回复 2023-09-18
  • 3 回答
  • 0 关注
  • 105 浏览

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信