Javascript - 选择元素子元素的第一个元素

时间:2014-01-28 13:19:00

标签: javascript html select

我有以下HTML:

<div class="list">
<div class="items">
    <ul>
        <li>IMPORTANT</li>
        <li>...</li>
        <li>...</li>
        <li>...</li>
        <li>...</li>
        <li>...</li>
    </ul>
    <ul>
        ...
    </ul>
</div>

现在我想通过Javascript在div“list”的div“items”中的第一个“ul”中选择第一个“li”。

5 个答案:

答案 0 :(得分:5)

您可以使用getElementByIdgetElementsByClassNamegetElementsByTagName的任意组合。

var divs = document.getElementsByClassName('items');
var uls = divs[0].getElementsByTagName('ul');
var lis = uls[0].getElementsByTagName('lo');
var li = lis[0];
// li is now the first list element of the first list inside the first div with the class "items"

如果你给一些元素一个id更容易,那么你可以使用一个 getElementById代替笨重的getElements_,而不必处理数组:

var div = document.getElementById('items');  // If the right <div> has an id="items"
var uls = div.getElementsByTagName('ul');
var lis = uls[0].getElementsByTagName('lo'); // Or instead of uls[0] give the right ul and id
var li = lis[0];                             // Or instead of lis[0] give the right li and id

最简单的解决方案可能是使用像jQuery这样的库,你可以用选择器来完成这个:

var li = $('div.items:first ul:first li:first');

修改: 如果您不能使用jQuery并且排除旧浏览器(主要是IE7或更低版​​本)没有问题,我建议使用David Thomas的解决方案。

答案 1 :(得分:4)

如果你的目标是现代浏览器,我建议:

var importantLi = document.querySelector('.list .items li');

参考文献:

答案 2 :(得分:1)

您的div通常为<div id="items"><div id="items" class="items">,因为ID的div在页面上是唯一的。

然后

firstLi = document.getElementById("items").firstChild.firstChild;

答案 3 :(得分:0)

使用 JQuery ,更容易定位

$(".list .items ul:first li:first")

OR

$("div.list div.items ul li").first()

参考 LIVE DEMO

答案 4 :(得分:-2)

你可以尝试这个<script>$('.items ul li:first').val()</script>