4

私はphantom.jsを初めて使用し、Webサイトページをナビゲートして、phantom.jsのリンク(AJAX関数を呼び出してドキュメントのHTMLを変更する)をクリックしようとしています。

これが私のコードです:

window.setTimeout(function(){
    phantom.exit();
}, 120000);

var page = require('webpage').create();

page.open("http://example.com", function(status) {
    if (status !== 'success') {
        console.log('{"error":"Unable to load the address for page"}');
        phantom.exit();
    }

    var action = page.evaluate(function() {
        document.getElementById("anID").click();
        return "clicked";
    });

    var results = page.evaluate(function() {
        return document.documentElement.innerHTML;
    });

    console.log(action);

    window.setInterval(function() {
        console.log(results);
        phantom.exit();
    }, 3000);
});

私の「アクション」関数のように、私は非常に混乱しています。click()呼び出しは、そのエラーを3回繰り返し発生させます。

TypeError:'undefined'は関数ではありません
phantomjs://webpage.evaluate():3 phantomjs://webpage.evaluate():1
ph.js:121 null

TypeError:'undefined'は関数ではありません
phantomjs://webpage.evaluate():3 phantomjs://webpage.evaluate():1
ph.js:121 null

TypeError:'undefined'は関数ではありません
phantomjs://webpage.evaluate():3 phantomjs://webpage.evaluate():1
ph.js:121 null

また、クリックを送信するときにその行にコメントを付けると、アクション関数はエラーを発生させなくなり、「クリックされた」コンソールログを適切に返します。でも3回...

私は何を間違っているのですか?

前もって感謝します。

4

1 に答える 1

5

私はついにこのコードで自分のタスクを達成することができました。クリックアクションをスキップして、AJAX呼び出しに直接移動しました。

    // phantomjs test.js 'http://www.example.com' 'anID'

    var system = require('system');
    var page = require('webpage').create();
    var url = system.args[1];
    var target = system.args[2];

    page.onConsoleMessage = function (msg) { 
        console.log(msg); 
        phantom.exit();
    };

    page.open(url, function (status) {
            function evaluate(page, func) {
                var args = [].slice.call(arguments, 2);
                var fn = "function() { return (" + func.toString() + ").apply(this, " + JSON.stringify(args) + ");}";
                return page.evaluate(fn);
            }
            page.injectJs('jquery-1.7.2.min.js');
            if (status === 'success') {
                    evaluate(page, function(target) {
                        $.ajax({
                          type: 'POST',
                          url: document.URL,
                          data: "__EVENTTARGET=" + target,
                          success: function(msg){
                                console.log(msg);
                            }
                        });
            }, target);
        }
    });
于 2012-04-12T18:02:18.200 に答える