3

我是 SpookyJS/CasperJS 的新手,我正在尝试弄清楚执行流程。

这就是我想要实现的目标:

  • 加载页面

  • 存储页面的图像

  • 将此图像传递给一个函数并执行它(这个过程很长:~15 秒)

  • 等待函数返回结果

  • 使用返回的值在加载的页面中填写表单中的一个字段

  • 提交表格

这是一个代码片段,试图解释我想出的解决方案:

var globProcessedImage;

try {
    var Spooky = require('spooky');
} catch (e) {
    var Spooky = require('../lib/spooky');
}

var spooky = new Spooky({
    child: {
        transport: 'http'
    },
    casper: {
        logLevel: 'debug',
        verbose: true
    }
}, function (err) {
    if (err) {
        e = new Error('Failed to initialize SpookyJS');
        e.details = err;
        throw e;
    }

    spooky.start('http://example.com/');

    spooky.then(function() {
        this.captureSelector('./image.png', '#img-node');
    });

    spooky.waitFor(function() {
        this.emit('image.processed');
        return globProcessedImage !== undefined;
    }, function then() {
        processedImage = globProcessedImage;
        this.sendKeys('#imagePassword', processedImage);
    });

    spooky.then(function() {
        this.capture('./page.png');
    });

    spooky.run();

    spooky.on('image.processed', function() {
        setTimeout(function() {
            globProcessedImage = 'my_result_string';
        }, 15000);
    });
});

spooky.on('error', function (e, stack) {
    console.error(e);

    if (stack) {
        console.log(stack);
    }
});

spooky.on('log', function (log) {
    if (log.space === 'remote') {
        console.log(log.message.replace(/ \- .*/, ''));
    }
});

当我运行应用程序时,我收到以下错误:

ReferenceError: Can't find variable: globProcessedImage

如何globProcessedImage在 SpookyJS 中显示?这是在 Web 自动化期间处理外部功能的正确方法吗?

提前致谢。

4

1 回答 1

0

编辑:在撰写本文时,SpookyJS 不支持将对象按值传递到waitFor回调中的附加语法。所以这段代码不起作用。

与 casperjs 相比,spookyjs 具有三种可能的上下文:spooky 上下文、casper 上下文和页面上下文。

您尝试的是从 casper 上下文访问在幽灵上下文中定义的变量。您可以在上下文之间传递变量,如本期所述:如何使全局变量可用于 casper 内部的函数?

因此,将其适应您的代码,您应该具有:

var globProcessedImage;

try {
    var Spooky = require('spooky');
} catch (e) {
    var Spooky = require('../lib/spooky');
}

var spooky = new Spooky({
    child: {
        transport: 'http'
    },
    casper: {
        logLevel: 'debug',
        verbose: true
    }
}, function (err) {
    if (err) {
        e = new Error('Failed to initialize SpookyJS');
        e.details = err;
        throw e;
    }

    spooky.start('http://example.com/');

    spooky.then(function() {
        this.captureSelector('./image.png', '#img-node');
        // start longRunning here
    });

    spooky.waitFor([{spookyGlobProcessedImage: globProcessedImage}, function() {
        return spookyGlobProcessedImage !== undefined;
    }], [{spookyGlobProcessedImage: globProcessedImage}, function then() {
        this.emit('image.processed', spookyGlobProcessedImage);
        processedImage = spookyGlobProcessedImage;
        this.sendKeys('#imagePassword', processedImage);
    }]);

    spooky.then(function() {
        this.capture('./page.png');
    });

    spooky.run();

    spooky.on('image.processed', function(spookyGlobProcessedImage) {
        this.echo("spookyGlobProcessedImage is " + spookyGlobProcessedImage);
    });
});

spooky.on('error', function (e, stack) {
    console.error(e);

    if (stack) {
        console.log(stack);
    }
});

spooky.on('log', function (log) {
    if (log.space === 'remote') {
        console.log(log.message.replace(/ \- .*/, ''));
    }
});

我不确定是否spooky.waitFor支持这种语法。

于 2014-05-15T18:15:30.427 回答