0

尽管我找到了几个选择 href 属性的答案,但它们都不适合我。也许有人可以帮忙。

html如下

<div class="galleryitem">
   <div class="itemlink">
      <a href="page1.html">Page</a>                 
   </div>
   <div class="itemimg">
      <a href="img/test1.png">test1.png</a>                 
   </div>
</div>

<div class="galleryitem">       
   <div class="itemlink">
    <a href="page1.html">Page 1</a>                 
   </div>
   <div class="itemimg">
      <a href="img/test2.png">test2.png</a>                 
   </div>
</div>

现在我想获取hrefs中的所有属性值并尝试使用

$('.galleryitem').each(function() {

   var link = $(this).children('itemlink a').attr('href');
   var img = $(this).children(".itemimg a").attr("href");       

   //jQuery("#somediv").append("<a href='" + link + "'><img class='cloudcarousel' src='" + img + "'/></a>");

});

我不知道为什么链接和 img 是未定义的。甚至 $(this).children('.itemlink a') 也是未定义的。

有人可以帮忙吗?

4

3 回答 3

2

尝试find

$('.galleryitem').each(function() {
    var link = $(this).find('itemlink a').attr('href');
    var img = $(this).find(".itemimg a").attr("href"); 
    //...
})
于 2013-11-06T19:46:40.733 回答
2

您想确定该.find()方法而不是.children仅获取直接后代的方法。(您还有一个小错误,缺少 中的句点itemlink

var link = $(this).find('.itemlink a').attr('href');
var img = $(this).find(".itemimg a").attr("href");       

应该适合你,这是一个小提琴:http: //jsfiddle.net/hQeu3/

不起作用的原因.children是没有与此选择器“.itemlink a”匹配的直接后代。jQuery 抓取 div(“.itemlink”),然后尝试过滤到选择器,在这种情况下失败。它基本上等于

$(this).children().filter('.itemlink a'); //won't work!

如果你想使用孩子,你可以做

$(this).children('.itemlink').children("a").attr('href');
于 2013-11-06T19:46:40.910 回答
1

您可以执行以下操作:

$('.galleryitem').each(function() {

   var link = $('.itemlink > a', this).attr('href');
   var img = $('.itemimg > a', this).attr('href');
});

考虑到这一点.itemlink并且.itemimg<a>元素的直接父级。

于 2013-11-06T19:49:05.737 回答