फैंटमजस - उदाहरण
इस अध्याय में, हम PhantomJS की कुछ महत्वपूर्ण विशेषताओं को समझने के लिए कुछ और व्यावहारिक उदाहरण प्रदान कर रहे हैं।
उदाहरण 1 - पृष्ठ गति ज्ञात करें
इस उदाहरण में, हम PhantomJS का उपयोग करेंगे page speed किसी भी दिए गए पृष्ठ URL के लिए।
var page = require('webpage').create(),
system = require('system'),
t, address;
if (system.args.length === 1) {
console.log('Usage: loadspeed.js <some URL>');
phantom.exit(1);
} else {
t = Date.now();
address = system.args[1];
page.open(address, function (status) {
if (status !== 'success') {
console.log('FAIL to load the address');
} else {
t = Date.now() - t;
console.log('Page title is ' + page.evaluate(function () {
return document.title;
}));
console.log('Loading time ' + t + ' msec');
}
phantom.exit();
});
}
उपरोक्त कार्यक्रम निम्नलिखित उत्पन्न करता है output।
Command - फैंटमज पेजस्पेड.जेएस http://www.google.com
Page title is Google
Loading time 1396 msec
उदाहरण 2 - एक पृष्ठ पर एक ईवेंट भेजें
निम्नलिखित उदाहरण में, हम एक भेजने के लिए PhantomJS का उपयोग करेंगे click event एक पृष्ठ के लिए।
var page = require('webpage').create();
page.onConsoleMessage = function(str) {
console.log(str);
}
page.open('http://phantomjs.org/api/phantom/', function(status) {
page.render('beforeclick.png');
console.log(page.url);
var element = page.evaluate(function() {
return document.querySelector('img[src = "http://phantomjs.org/img/phantomjslogo.png"]');
});
page.sendEvent('click', element.offsetLeft, element.offsetTop, 'left');
window.setTimeout(function () {
console.log(page.url);
page.render('afterclick.png');
phantom.exit();
}, 5000);
console.log('element is ' + element);
});
उपरोक्त कार्यक्रम निम्नलिखित उत्पन्न करता है output।
http://phantomjs.org/api/phantom/
element is [object Object]
http://phantomjs.org/
हमारा कार्यक्रम निम्नलिखित दो का निर्माण करेगा png में चित्र binफ़ोल्डर। उपरोक्त कार्यक्रम के क्रियान्वयन से पहले और बाद में इन दो छवियों में अंतर दिखाई देता है।
उदाहरण 3 - एक फॉर्म जमा करें
निम्नलिखित उदाहरण से पता चलता है कि फैंटमज का उपयोग करके फॉर्म कैसे जमा करें।
var wpage = require('webpage').create();
wpage.open("http://localhost/tasks/submitform.html", function(status) {
console.log(status);
wpage.uploadFile('input[name = fileToUpload]', 'output.png');
wpage.render("sform.png");
var element = wpage.evaluate(function() {
return document.querySelector('input[type = "submit"]');
// getting details of submit button using queryselector.
});
wpage.sendEvent('click', element.offsetLeft, element.offsetTop, 'left');
// sendevent is used to send click event and also giving the left and top
position of the submit button.
window.setTimeout(function () {
console.log(wpage.url);
wpage.render("submit.png"); // screenshot is saved in submit.png
phantom.exit();
}, 5000);
console.log('element is ' + element);
});
submitform.html
निम्न कोड दिखाता है कि कैसे उपयोग करना है submitform.html फ़ाइल।
<html>
<head>
<title>Window 2</title>
</head>
<body>
<form action = "submitform.php" method = "post" enctype = "multipart/form-data"
id = "form1">
<input type = "file" name = "fileToUpload" id = "fileToUpload">
<input type = "submit" value = "Upload Image" name = "submit">
</form>
</body>
</html>
एक बार फॉर्म जमा करने के बाद, यह जाता है submitform.php।
submitform.php
submitform.php सिर्फ फाइलों के विवरण को प्रिंट कर रहा है।
<?php
print_r($_FILES);
?>
उपरोक्त कार्यक्रम निम्नलिखित उत्पन्न करता है output।
Success
element is [object Object]
http://localhost/tasks/submitform.php
इमेजिस
इसके लिए चित्र निम्नलिखित हैं file upload तथा form submit।