phantomJs 快速入门学习 了解大概 - 孔扎根
1、hellow程序
一个永远的开头,创建一个文件hello.js。内容如下
//hello.js
//在窗口输出信息 console.log(\'Hellow ,Word\');
//退出程序,每个脚本必须有 phantom.exit();
运行程序
2、页面加载
创建一个文件myload.js
webpage是phantomjs的最重要的一个函数,用于初始化一个无头浏览器实例。
//myload.js
//创建一个无头浏览器实例 var page = require(\'webpage\').create();
//open函数:第一个参数为要访问的url地址,第二个参数为访问url后的回调函数,function参数默认为访问url后的状态值 page.open(\'http://example.com\',function(status){ console.log("logging stats :"+status); if (status == \'success\'){ page.render(\'examp.jpg\'); }
//如果没有,程序就不会退出 phantom.exit(); }
运行程序,此时c:\myjs\下生成了examp.jpg图片
3、加载速度测试
创建一个文件loadspeed.js,system是系统涵数,可以与系统环境做交互,system.args为系统传入的参数。
//loadspeed.js var page = require(\'webpage\').create(), system = require(\'system\'), t, address; if (system.args.length === 1) { console.log(\'Usage: loadspeed.js <some URL>\'); phantom.exit(); } 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(\'Loading \' + system.args[1]); console.log(\'Loading time \' + t + \' msec\'); } phantom.exit(); });
运行程序
4、执行js代码,evaluate函数用来执行js代码
//executecode.js page = require(\'webpage\').create();
// Open打开请求的URL page.open(\'http://example.com/\',function(status){
// evaluate对返回的文档执行JS程序 var title = page.evaluate(function(){ return document.title; }); console.log(title); phantom.exit(); })
运行程序
5、console.log在evaluate函数中是不能输出的。onConsoleMessage事件监听evaluate中的所有console.log.
var page = require(\'webpage\').create(); page.onConsoleMessage = function(msg) { console.log(\'Page title is \' + msg); }; page.open(
\'http://example.com/\'
, function(status) { page.evaluate(function() { console.log(document.title); }); phantom.exit(); });
6、网络请求与响应
当发起一个远程服务器的页面请求的时候,请求与响应都能通过onResourceRquested与onResourceReceived的回调函数跟踪
var page = require(\'webpage\').create(); page.onResourceRequested = function(request) { console.log(\'Request \' + JSON.stringify(request, undefined, 4)); }; page.onResourceReceived = function(response) { console.log(\'Receive \' + JSON.stringify(response, undefined, 4)); }; page.open(\'http://example.com/\');