4

这是我的代码:

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

function updateCars(){

    function getReviews(body){
        var $ = cheerio.load(body);
        var year = $(this).find(".field-item").text();
    }

    async.series([
        ....
        function(callback) {
            request(site+path, function(err, resp, body){
                if(!err && resp.statusCode == 200){
                    var $ = cheerio.load(body);
                    $(".views-row").each(getReviews(body));
                }
            });
        }
    ]);
}

当我在节点控制台中运行它时,出现以下错误:

SyntaxError: Malformed attribute selector: object global]

我该如何解决?

4

1 回答 1

1

错误...

SyntaxError:格式错误的属性选择器:对象全局]

实际上是一针见血。由于此处仅发布了违规代码的片段,因此尚不完全清楚发生这种情况的位置,但这绝对是属性选择器中的笔误 - 很可能是这个......

回答:

$('div[id^=foo_bar'); // <-- missing the closing ]

上面的例子是一个你通常(或者你正在抓取的网站的编码者)不会注意到的错误,因为 jQuery 通常会悄悄地处理这个错误......

证明 jQuery 处理它:

var fooBars = $('a[id^="foo_bar"'); //<-- missing closing ]
$('#results').append("See... jQuery don't care about your closing ']' -" + fooBars.length)
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<a id="foo_bar_1">1</a>
<a id="foo_bar_2">2</a>
<a id="foo_bar_3">3</a>
<a id="foo_bim_4">4</a>
<a id="foo_bar_5">5</a>

<div id="results"></div>

解释:

这个错误实际上是Sizzle从Cheerio下方的某个地方对你大喊大叫。虽然 jQuery 正在使用纯 javascript 实现......

var fooBar = document.querySelectorAll('a[id="foo_bar"'); // <-- missing
alert(fooBar.length); // works!

Cheerio 正在使用 Sizzle,它不喜欢“格式错误”的属性(在 IE 7-9 中也曾是一个问题)......

与 jQuery 一样,[Cheerios] 是在文档中选择元素的主要方法,但与 jQuery 不同的是,它建立在 CSSSelect 库之上,该库实现了大多数 Sizzle 选择器。

于 2016-04-14T21:11:30.447 回答