2017-04-05 7 views
0

phantomjs/casperjsに初心者です。 私はjavascript関数(href = 'javascript:getPhoneNumber(....))を持つhrefをクリックしようとしていますが、png画像の印刷結果を取得したいのです。ここ は、クリックする前に、HTMLのブロックです:casperjs/phantomjs href = "javascript:function"をクリックして結果のコンテンツを取得する方法

<div class="logo_text_link"> 

    <img class="logo_text_link" src="//static.awebsite.com/img/devices/mobile/awebsite_mobile_view_phone.png" alt="Telephoner"> 

    <span id="phoneNumber"><a class="nohistory adview_links" href='javascript:getPhoneNumber("https://api.awebsite.com", 1117004764, "54bb0281238b45a03f0ee695f73e704f")'>See&nbsp;the&nbsp;number&nbsp;</a></span 
</div> 

、ここでは、HTMLブロックは、クリック後です:casperjsを使用してIMGリンク(HREF)を得ることを目指し

<div class="logo_text_link"> 

    <img class="logo_text_link" src="//static.awebsite.com/img/devices/mobile/awebsite_mobile_view_phone.png" alt="Telephoner"> 

    <span id="phoneNumber"><div class="phoneimg"></div><img class="AdPhonenum" src="https://www.awebsite.com/pg/0f/AxLHLu0zHVAtWTp+nJCc2KkcZTdPfX3CM=.gif"></span> 

</div> 

I'am。イムので、それを使用する新しい私は多く、実際に試していない:このタスクを成し遂げるためにどのように誰もが知っている場合はS

var casper = require('casper').create(); 
casper.start("http://mobile.awebsite.com/ventes_immobilieres/1117004764.htm?ca=12_s"); 
var a="dd"; 
casper.echo('before then'); 

casper.then(function() { 
     b=casper.click(x('//*[@id="phoneNumber"]/a')); 
     casper.evaluate(function() { 
      a = getPhoneNumber("https://api.awebsite.com", 1117004764, "54bb0281238b45a03f0ee695f73e704f") ; 
     }); 
     casper.echo(a); 
     casper.echo(b); 


}); 

casper.run(); 

私は(私は今、2日間に苦労してきた)本当に感謝されると思います!

答えて

1

長いコードサンプルにコメントを付けて答えを出しました。重要なポイントをよりよく説明するために実際のサイトを使用しました。そのサイトを開き、スクリプトの内容を確認してください。

var img; // We only really need one variable to get that image address 

// Let's create a CasperJS instance that tries (although not fanatically) 
// to mimic a browser: it has a real resolution instead of default 400x300 
// and a Chrome useragent (better to use those to not confuse websites into thinking 
// this is a mobile browser with small screen; they could even redirect to a mobile version) 
// Of course if you _want_ a mobile version use resolution and useragent of a mob.browser 
var casper = require('casper').create({ 
    pageSettings: { 
     userAgent: "Mozilla/5.0 (Windows NT 6.1; WOW64) AppleWebKit/537.36 (KHTML, like Gecko) Chrome/51.0.2704.106 Safari/537.36" 
    }, 
    viewportSize : { width: 1280, height: 1024 }, 
    verbose: true 
}); 
var x = require('casper').selectXPath; 

casper.start("http://www.autreys.com/categories/firearms.html"); 

casper.then(function() { 
    // make screenshots often to check that CasperJS sees what you think it sees 
    casper.capture("1-before-click.jpg");  

    // Click on the first button of this type to open a lightbox 
    casper.click(x('(//*[@class="QuickViewBtn"])[1]')); 
}); 

console.log("This will be output before everything else because it is not put in the queue like casper.then or casper.wait"); 

// Give the lightbox some time to load (3 seconds) 
casper.wait(3000); 

// After that let's get the cover image from the lightbox 
casper.then(function() { 
    casper.capture("2-after-click.jpg");  
    img = casper.evaluate(function() { 
     // This happens "in the browser" 
     // You cannot assign local variables like "img" here 
     // Just return variables "back" 
     return document.querySelector("#QuickViewImage img").src; 
    }); 
    console.log(img); 
}); 

casper.run(); 
+0

質問に実際のURLを入力する方がよいでしょう。 – Vaviloff

関連する問題