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

globProcessedImageSpookyJS で可視化するにはどうすればよいですか? これは、Web 自動化中に外部関数を処理するための正しいアプローチですか?

前もって感謝します。

4

1 に答える 1

0

編集:これを書いている時点で、SpookyJS はオブジェクトを値でwaitForコールバックに渡す追加の構文をサポートしていませんでした。したがって、このコードは機能しません。

casperjs とは対照的に、spookyjs には、spooky コンテキスト、casper コンテキスト、および page コンテキストの 3 つの可能なコンテキストがあります。

あなたがしようとしているのは、casper コンテキストから不気味なコンテキストで定義されている変数にアクセスすることです。この問題で説明されているように、コンテキスト間で変数を渡すことができます: How to make global variables available to functions inside 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 に答える