PhantomJS not returning results

前端 未结 1 599
南方客
南方客 2021-01-06 11:32

I\'m testing out PhantomJS and trying to return all startups listed on angel.co. I decided to go with PhantomJS since I would need to paginate through the front page by clic

相关标签:
1条回答
  • 2021-01-06 11:54

    By default, console messages evaluated on the page will not appear in your PhantomJS console.

    When you execute code under page.evaluate(...), that code is being executed in the context of the page. So when you have console.log((i + 1) + ":" + list[i].innerText);, that is being logged in the headless browser itself, rather than in PhantomJS.

    If you want all console messages to be passed along to PhantomJS itself, use the following after opening your page:

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

    page.onConsoleMessage is triggered whenever you print to the console from within the page. With this callback, you're asking PhantomJS to echo the message to its own standard output stream.

    For reference, your final code would look like (this prints successfully for me):

    var page = require('webpage').create();
    
    page.open('https://angel.co/startups', function(status) {
        page.onConsoleMessage = function (msg) { console.log(msg); };
        if (status !== 'success') {
            console.log('Unable to access network');
        } else {
             page.evaluate(function() {
                var list = document.querySelectorAll('div.resume');
                for (var i = 0; i < list.length; i++){
                   console.log((i + 1) + ":" + list[i].innerText);
                }
             });
        }
        phantom.exit();
    });
    
    0 讨论(0)
提交回复
热议问题