节点Jquery刮擦问题

时间:2014-09-19 17:06:18

标签: javascript jquery node.js request cheerio

我正在尝试在我的网页上运行一个简单的刮,但我遇到的问题是我似乎无法正确地使用我的刮刀选择HTML元素。我认为我正在从<li>正确地抓取属性,但我为每个对象属性获取了undefined值。

我希望获取data-namedata-addressdata-url值。

scrape.js

var request = require('request');
var cheerio = require('cheerio');

request('http://personalSite.com', function (error, response, html) {
  if (!error && response.statusCode == 200) {
    var $ = cheerio.load(html);

    $('li').each(function(i, element){

        var li = $(this).contents();


        var name = li.attr('name');
        var address = li.attr('address');
        var url = li.attr('url');


        var metadata = {
            name : name,
            address : address,
            url : url
        };
        console.log(metadata);
    });
  }
});

HTML:

<li id="v1065" data-name="Jerry's Food" data-address="5120 West 43rd Street"  data-url="http://www.testsite1.com/" data-category="1"><a href="#" class="list-digital">
                                    <span class="venue-name">Jerry's Food</span><br />
                                    <span class="venue-address">5120 West 43rd Street</span>

                                    </a>
                                </li>                           
                                <li id="v249" data-name="Accel Partners" data-address="13482 Seventh Avenue" data-url="http://www.testsite2.com" data-category="3"><a href="#" class="list-digital">
                                    <span class="venue-name">Mike's Pizza</span><br />
                                    <span class="venue-address">13482 Seventh Avenue</span>                             
                                    </a>
                                </li>                           

1 个答案:

答案 0 :(得分:0)

使用.attr()方法,您应该使用完整的属性名称

var name = li.attr('data-name');
var address = li.attr('data-address');
var url = li.attr('data-url');

或者您可以使用

var name = li.data('name');
var address = li.data('address');
var url = li.data('url');