简单来说,phantomjs就是一个运行在node上的webkit内核,支持DOM渲染,css选择器,Canvas,SVG等,在浏览器上能做的事情,理论上,phantomjs 都能模拟做到。

  phantomjs 使用场景:  

  页面自动化测试: 无需浏览器的情况下进行快速的Web测试,且支持很多测试框架,如YUI Test、Jasmine、WebDriver、Capybara、QUnit、Mocha等。 网页监控: 定期打开页面,检查网站是否正常加载,加载结果是否符合预期等 页面截图:以编程方式抓起CSS、SVG和Canvas等页面内容 网络爬虫:抓取网络页面

  phantomjs 安装:

npm install  phantomjs  -g

  phantomjs 事件就是精确插入点

  为了能够在精确的时间点注入测试脚本,我们需要了解下 phantomjs 在请求资源时会发生哪些事件,毕竟它也是一个事件驱动模型。

    onInitialized 类似于我们发送 ajax 请求,状态为 0 的时候
    onLoadStarted 准备加载网页,此时页面的 page.content 是存在的,内容为 <html><body></body></html>
    onLoadFinished 页面加载完成,是 DOMContentLoaded 还是 window.onload,我稍微测试了下,感觉应该是后者
    onResourceRequested 请求资源,如 css、js 等
    onResourceReceived 请求的资源已到达
    onClosing 关闭页面
    onConsoleMessage 沙箱内的 console 内容是不会出现到外层的,通过这个函数可以输出

  还有很多,具体可以翻阅文档: http://phantomjs.org/api/webpage/

  以下是我写的部分demo,仅供参考phcaTest.js:

//http://javascript.ruanyifeng.com/tool/phantomjs.html
//http://div.io/topic/1366
//http://imweb.io/topic/556c287879878a3b386dd026
//http://www.cnblogs.com/xinzhyu/p/4214669.html
//http://www.cnblogs.com/ziyunfei/archive/2012/09/27/2706254.html
//http://wiki.jikexueyuan.com/project/node-lessons/mocha-chai-phantomjs.html var webPage = require('webpage'); var files = [
{url:"http://pingfan1990.sinaapp.com/html5/pfgame/index.html",name:"game"},
{url:"http://pingfan1990.sinaapp.com/festival/index.html",name:"festival"},
{url:"http://pingfan1990.sinaapp.com/html5/travel/index.html",name:"travel"},
{url:"http://pingfan1990.sinaapp.com/html5/StackBlur/index.html",name:"blur"},
{url:"http://pingfan1990.sinaapp.com/html5/ScratchGirls/index.html",name:"scratch"},
{url:"http://wq.111.com/fd/promote/201509/s11/mainvenue.html",name:"main"}
]; files.forEach(function(item,index){
//console.log(index);
//createPic(item.url,item.name);
eventCreatePic(item.url,item.name,480,2000);
}); var count = 0; function createPic(url,picname,width,height){
var page = webPage.create(); //设置截图放大系数,尺寸
page.zoomFactor = 1; page.clipRect = { top: 0, left: 0, width: width, height: height }; page.viewportSize = {
width: width,
height: height
}; page.settings = {
javascriptEnabled: true,
loadImages: true,
userAgent: 'Mozilla/5.0 (Windows NT 6.1) AppleWebKit/537.31 (KHTML, like Gecko) PhantomJS/19.0'
}; page.open(url,function(status){ //evaluate在页面中执行JavaScript代码
var title = page.evaluate(function() {
return document.title;
}); //includeJs方法用于页面加载外部脚本,加载结束后就调用指定的回调函数
/*page.includeJs("http://path/to/jquery.min.js", function() {
console.log(111);
});*/ if (status === 'fail') {
console.log('open page fail!');
} else {
page.render('./phantom/'+picname+".jpg", {format: 'jpeg', quality: '100'});
console.log('Page title is ' + title);
}
count++;
if(count === files.length){
console.log("截图生成完毕,phantomjs退出运行!");
phantom.exit();
}
page.close();
//phantom.exit();
});
} function eventCreatePic(url,picname,width,height){
var page = webPage.create(); page.clipRect = { top: 0, left: 0, width: width, height: height }; page.viewportSize = {
width: width,
height: height
};
page.onLoadStarted = function(){
//console.log("开始进入页面");
}
page.onLoadFinished = function(){
page.render('./phantom/'+picname+".jpg", {format: 'jpeg', quality: '100'});
page.close();
count++;
if(count === files.length){
console.log("截图生成完毕,phantomjs退出运行!");
phantom.exit();
}
}; page.open(url,function(status){
//evaluate在页面中执行JavaScript代码
var title = page.evaluate(function() {
return document.title;
});
if (status === 'fail') {console.log('open page fail!');}
console.log('Page title is '+title);
});
}

  结合node进程:

var fs = require("fs"),
child_process = require("child_process"),
http = require("http"); console.log("看是配合node+phantomjs玩法开始!"); var phan = child_process.exec("phantomjs phcatest.js",function (error, stdout, stderr) {
if (error) {
console.log(error.stack);
console.log('Error code: ' + error.code);
}
console.log('Child Process STDOUT: ' + stdout);
}); /*var phan = child_process.spawn("phantomjs",["phcatest.js"]);
phan.stdout.on('data', function (data) {
console.log('stdout: ' + data);
}); phan.stderr.on('data', function (data) {
console.log('stderr: ' + data);
}); phan.on('close', function (code) {
console.log('child process exited with code ' + code);
});*/

注意按照phantomjs的问题,由于phantomjs资源包被墙的限制,按照时建议大家采用淘宝镜像源

ios下推荐通过brew install phantomjs安装。

资料来源:

  phantomjs小试

  phantomjs 基础

  浏览器端测试:mocha,chai,phantomjs

  CasperJS,基于PhantomJS的工具包

  casperjs.org

  PhantomJS bridge for NodeJS

  阮老师PhantomJS

  利用nodejs+phantomjs+casperjs采集淘宝商品的价格

  前端自动化测试工具:SlimerJS、phantomJS 和 CasperJS

phantomjs试玩的更多相关文章

  1. HTML5+JS 《五子飞》游戏实现(七)游戏试玩

    前面第一至第六章我们已经把<五子飞>游戏的基本工作都已经讲得差不多了,这一章主要是把所有的代码分享给大家,然后小伙伴们也可以玩一玩. 至于人机对战的我们放到后面讲进行分析. 试玩地址:ht ...

  2. 一个小玩意 PHP实现微信红包金额拆分试玩

    <meta charset="utf-8"> <?php // 新年红包金额拆分试玩 class CBonus { public $bonus;//红包 publ ...

  3. 1.2G内存试玩RAMOS_XP

    1.2G内存试玩RAMOS_XP1.为了防止做系统时出现意外,用Bootice把C盘MBR修改为Grub4dos,这样子系统如果失败,可以进入PE重做. 2.进入PE格式化C盘,格式化的时候勾选启用N ...

  4. 8个经典的HTML5游戏在线试玩及源码学习

    原文地址:http://www.oschina.net/news/32364/html5-games 游戏,毫无疑问是拿来供大家娱乐玩耍的,这也无可厚非,但是,今天给大家分享的8个HTML5游戏,在好 ...

  5. Apollo框架试玩

    2017年7月5日,百度举行了AI开发者大会,在会上发布了Apollo项目,并进行了演示,该项目在Github上已经能够被访问.出于一个程序员的好奇,昨天试玩了一把,确实不错. http://apol ...

  6. 发布到FaceBook试玩广告,FaceBook要求要一个Html文件

    Facebook 试玩广告具体要求: 试玩广告参数是创建试玩广告素材时要满足的要求. 试玩素材应为 HTML5 格式. 试玩广告素材不应使用 mraid.js 格式. 包含所有素材的试玩广告的单个 H ...

  7. [试玩] FMXLinux (Firemonkey for Linux) Linux 桌面开发(第三方插件)

    FMXLinux 是一个可以用来开发 Linux 桌面软件的第三方插件,它需要配合 Delphi 10.2 Toyko 官网:http://www.fmxlinux.com/ 使用方法:开启 FMX ...

  8. ESP32 LyraT音频开发板试玩(二):播放音乐

    我是卓波,很高兴你来看我的博客. 系列文章: ESP32 LyraT音频开发板试玩(一):搭建开发环境 ESP32 LyraT音频开发板试玩(二):播放音乐 本文延续上一篇博客 将D:\msys32\ ...

  9. ESP32 LyraT音频开发板试玩(一):搭建开发环境

    我是卓波,很高兴你来看我的博客. 系列文章: ESP32 LyraT音频开发板试玩(一):搭建开发环境 ESP32 LyraT音频开发板试玩(二):播放音乐 关于ESP32的开发环境搭建,官方有教程, ...

随机推荐

  1. .NET 4并行编程入门之Task的取消[转]

    原文:http://www.cnblogs.com/Leo_wl/archive/2010/06/01/1749596.html前言:因为Task是.NET 4并行编程最为核心的一个类,也我们在是在并 ...

  2. Android开发中常用的库总结(持续更新)

    这篇文章用来收集Android开发中常用的库,都是实际使用过的.持续更新... 1.消息提示的小红点 微信,微博消息提示的小红点. 开源库地址:https://github.com/stefanjau ...

  3. BarTender 2016表单中的“秤显示”控件

    BarTender 2016中的表单是一个非常实用的工具,它可以实现数据输出提示,查询提示和同一表单的记录选择.这些都离开可供添加的控件,“秤显示”控件也是我们打印尝尝需要涉及的,今天我们就来看看什么 ...

  4. opencv在同一窗口打印多张图片

    首先,由于cv2处理的图片是通过ndarray的格式操作的,也就是说通过array的拼接就可以实现图片的拼接,那么之后就可以通过简单的imshow将合并的图片打印从而达到在一个窗口中显示多张图片的目的 ...

  5. 关于测试中哪些信息需要放到jira上面

    1.每个新需求的功能点,全部在jira上一一呈现 2.每个bug也一样在jira上一一呈现 3.任务一个需要优化改进的点也一一在jira上呈现 然后程序员一直开发新功能和修改新bug,测试人员负责bu ...

  6. faster-rcnn原理及相应概念解释

    R-CNN --> FAST-RCNN --> FASTER-RCNN R-CNN: (1)输入测试图像: (2)利用selective search 算法在图像中从上到下提取2000个左 ...

  7. 2、一、Introduction(入门):1、Application Fundamentals(应用程序基础)

    一.Introduction(入门) 1.Application Fundamentals(应用程序基础) Android apps are written in the Java programmi ...

  8. java命令行操作

    一直使用eclipse操作java程序,但RMI程序需要命令行操作,故研究了下java的命令行操作. javac 用于编译.java文件,生成.class文件 假设文件夹dir下有pa.java和a. ...

  9. /usr/bin/ld: cannot find -lxxx 的解决办法

    /usr/bin/ld: cannot find -lxxx 的解决办法 在软件编译过程中,经常会碰到类似这样的编译错误: /usr/bin/ld: cannot find -lhdf5 这表示找不到 ...

  10. 使用 urllib 解析 URL 链接

    urllib 库还提供了 parse 模块,它定义了处理 URL 的标准接口,例如实现 URL 各部分的抽取.合并以及链接转换,常用的方法如下: In []: from urllib.parse im ...