cheerio / jquery选择器:如何获取嵌套div中的元素列表?

时间:2015-09-18 14:56:30

标签: node.js jquery-selectors cheerio

我需要从html页面解析一些与此类似的标记:

<div id="list">

  <div class="item-level-a">
    <div class="item-level-b">
      <a href="http://www.example.com/1"></a>
    </div>
  </div>

  <div class="item-level-a">
    <div class="item-level-b">
      <a href="http://www.example.com/2"></a>
    </div>
  </div>

  <div class="item-level-a">
    <div class="item-level-b">
      <a href="http://www.example.com/3"></a>
    </div>
  </div>

</div>

我确实试过这段代码:

$list = [];
$('div[id="list"]').each(function() {
  var href = $(this).find('div > div > a').attribs('href');
  list.push(href);
});

没有成功:错误是:

TypeError: Object <a href="http://www.example.com/1"></a>
                  <a href="http://www.example.com/2"></a>
                  <a href="http://www.example.com/3"></a>
has no method 'attribs'

: - (

有任何线索吗?

2 个答案:

答案 0 :(得分:8)

cheeriojquery中,您获得attr()而不是attrib()的属性。

您的代码还有其他一些问题。这是使用cheerio的工作版本。它也可能以jquery的方式工作。:

var list = [];
$('div[id="list"]').find('div > div > a').each(function (index, element) {
  list.push($(element).attr('href'));
});
console.dir(list);

答案 1 :(得分:1)

对于那些偏爱功能性风格的人:

const list = $('div[id="list"]')
  .find('div > div > a')
  .toArray()
  .map(element => $(element).attr('href')));