比较innerText / textContent与变量内的值

时间:2018-06-26 19:15:46

标签: javascript html web-scraping nightmare

我正在使用Nightmare.js进行网络抓取,并尝试向具有特定文本的按钮添加ID,以便我可以单击它,因为该页面是使用javascript动态生成的。下面的代码不起作用,因为出于某种原因,我无法在if语句的indexOf内部使用变量。

const Nightmare = require('nightmare')
const nightmare = Nightmare({ show: false })
const rp = require('request-promise');
const cheerio = require('cheerio');

var size = "9";

nightmare
  .goto('https://www.flightclub.com/')
  .type('#search', 'air jordan 4 cactus jack \u000d')
  .wait(1000)
  .click('.result-thumbnail')
  .evaluate(() => {
    var correctSize = document.getElementsByTagName('button');
    for (var i = 0; i < correctSize.length; i++) {
      if (correctSize[i].textContent.indexOf(size) > -1) correctSize[i].id = 'thisone';
    }
  })
  .click('button[id=thisone]')
  .end()
  .catch(error => {
    console.error('Search failed:', error)
  })

但是,如果我将其更改为

if (correctSize[i].textContent.indexOf("9") > -1) correctSize[i].id ='thisone';

其中"9"代替size。我为什么不能为变量执行indexOf但可以使用具有相同值的常规字符串进行解释?我该如何解决?

1 个答案:

答案 0 :(得分:1)

该变量不是您在节点范围内定义的变量,因为评估在浏览器范围内运行。您需要传递变量以进行如下评估

  .evaluate((____size) => {
    var correctSize = document.getElementsByTagName('button');
    for (var i = 0; i < correctSize.length; i++) {
      if (correctSize[i].textContent.indexOf(____size) > -1) correctSize[i].id = 'thisone';
    }
  }, (____size))

然后有效

假设您将变量命名为____ size ...