我是javascript / jquery的新手。
我正在尝试从li
元素中选择一个div
,我将放置3张图片。所以我有这个变量:
var x = ui.item.parent().children()[i]
哪个是li
(它有效,我检查了ID),但是如何从x
获取div? (之后所有3张图片,所以我可以更改图像的z-index
,我也不知道如何)。
<ul>
<li id="li1">
<div>
<img class="1" src="img1.jpg" style="position:absolute;z-index=1">
<img class="2" src="img2.jpg" style="position:absolute;z-index=2">
<img class="3" src="img3.jpg" style="position:absolute;z-index=3">
</div>
</li>
</ul>
这是我写的代码,但是没有用(错误:未捕获TypeError:对象#没有方法'找')
for(var i=0;i<ui.item.parent().children().length-4;i++){
var x =ui.item.parent().children()[i];
x.find('img').css('z-index', '2');
}
答案 0 :(得分:1)
请更正您的HTML。你的ul在你之前结束了。 获得jQuery元素后,可以使用.find()函数搜索其子元素。
例如:
var x = $('li#yourid');
x.find('img').css('z-index', '2');
答案 1 :(得分:0)
您的HTML无效,您在li
之后关闭ul
标记,而li
没有开放标记<
。
正确的HTML是:
<ul>
<li id="li1">
<div>
<img class="1" src="...">
<img class="2">
<img class="3">
</div>
</li>
<ul>
现在要从x获取div,您需要使用.find()
:
var div = x.find('div');
答案 2 :(得分:0)
像这样使用
$("ul li").children("div").find("img").each(function(){
alert($(this).attr('class'));
});
答案 3 :(得分:0)
我不知道HTML是否只是一个例子,但格式不正确。它应该是:
<ul>
<li id="li1">
<div>
<img class="1" src="..."/>
<img class="2"/>
<img class="3"/>
</div>
</li>
</ul>
设置z-index:$(x).find('img')。css('z-index','100');