Node.js 单击未执行噩梦的函数。js

Node.js 单击未执行噩梦的函数。js,node.js,nightmare,Node.js,Nightmare,我正试着用梦魇来做些刮擦,我的工作几乎可以正常工作了。问题是,在调用了evaluate()和run()之后,我尝试执行click()时遇到了一个问题。运行这两个函数后,我尝试再次单击以将自己移动到网站的另一部分,但没有执行click() 在这一点上,我注意到了问题所在,我有一些假设,可能这些函数是异步的,我正在尝试click(),当回调还没有准备好,或者其中一个函数结束了当前的dream对象,我不再有作用域 var Nightmare = require('nightmare'); //var

我正试着用梦魇来做些刮擦,我的工作几乎可以正常工作了。问题是,在调用了
evaluate()
run()
之后,我尝试执行
click()
时遇到了一个问题。运行这两个函数后,我尝试再次单击以将自己移动到网站的另一部分,但没有执行
click()

在这一点上,我注意到了问题所在,我有一些假设,可能这些函数是异步的,我正在尝试
click()
,当回调还没有准备好,或者其中一个函数结束了当前的
dream
对象,我不再有作用域

var Nightmare = require('nightmare');
//var nightmare = Nightmare({show:true})
var express = require('express');
var fs = require('fs');
var request = require('request');
var cheerio = require('cheerio');
var app     = express();

var urlWeb = "someurl";
var selectCity = "#ddl_city";
var selectTheater = "#ddl_theater";
var enterBtn = "#btn_enter";
var mainSelector = "#aspnetForm";
var flagReady = true;

new Nightmare({show:true})
.goto(urlWeb)
.wait(selectCity)
.select(selectCity, '19')
.wait(8000)
.select(selectTheater, '12')
.wait(1000)
.click(enterBtn)
.wait(mainSelector)
.evaluate(function(){

        //returning HTML for cheerio
        return document.body.innerHTML; 
})
.run(function(err, nightmare){
     if (err) return console.log(err);

    // Loading HTML body on jquery cheerio
     var $ = cheerio.load(nightmare);

    //Looping on each div for seccion de Carterla para Hoy
    $('.showtimeDaily').each(function(index, element){
        //spanish title
        console.log($(this).find('h3').children().text());
        //english title
        console.log($(this).find('h4').text());
        //schedule for today
        console.log($(this).find('li').children().text() + " ");
        //img for movie
        console.log($(this).find('img').attr('src'));
            //show time data such as gender, lenght, language
        console.log($(this).find('.showtimeData').text());
        var showtimeData = $(this).find('.showtimeData').text();
        //console.log(JSON.stringify(showtimeData.replace(/\t|\n/g, "")));
    })

        console.log('Done!');


})
//*****here is wen I try to click*****
.click('a[href="../showtimes/weekly.aspx"]');

我遇到了异步回调的问题,所以我所做的是嵌套了梦魇对象的调用,以确保任务一个接一个地运行。代码如下:

nightmare
.goto(urlWeb)
.wait(selectCity)
.select(selectCity, '19')
.wait(8000)
.select(selectTheater, '12')
.wait(1000)
.click(enterBtn)
.wait(mainSelector)
.evaluate(function(){

        //returning HTML for cheerio
        return document.body.innerHTML; 
})
.then(function(body){
    // Loading HTML body on jquery cheerio
     var $ = cheerio.load(body);

    //Looping on each div for seccion de Carterla para Hoy
    $('.showtimeDaily').each(function(index, element){
        //spanish title
        console.log($(this).find('h3').children().text());
        //english title
        console.log($(this).find('h4').text());
        //schedule for today
        console.log($(this).find('li').children().text() + " ");
        //img for movie
        console.log($(this).find('img').attr('src'));
            //show time data such as gender, lenght, language
        console.log($(this).find('.showtimeData').text());
        var showtimeData = $(this).find('.showtimeData').text();
        //console.log(JSON.stringify(showtimeData.replace(/\t|\n/g, "")));
    })
   //**Here I call nightmare to run after the first call back is done*****
    nightmare
        .goto('')
        .wait('body')
        .title()
        .then(function(title){
            console.log(title);
        });

        console.log('Done!');


});