在 nightmare 基础上做了扩展,保持了其原始的功能,并提供一些工具。
$ npm install nightmare-handler
const nightmareHandler = require('nightmare-handler');
// 获得扩展之后的 Nightmare
const NightmarePlus = nightmareHandler.getNightmarePlus();
// 初始化 nightmare 对象
const nightmare = NightmarePlus({ show: true });
// 执行
nightmare
.exDevice('mobile')
.goto('http://www.baidu.com')
.wait('#index-bn')
.evaluate(function () {
return {
title: document.title,
searchBtnTxt: document.querySelector('#index-bn').innerText,
width: window.innerWidth,
height: window.innerHeight,
userAgent: navigator.userAgent
};
})
.end()
.then(function (result) {
console.log('success: ', result);
})
.catch(function (error) {
console.error('error: ', error);
});
import { Nightmare, getNightmarePlus } from 'nightmare-handler';
Nightmare
就是 nightmare ,而 getNightmarePlus(config)
方法返回的对象是对 Nightmare
进行了扩展(Extending Nightmare )等处理。
getNightmarePlus(config)
参数说明:
config.deviceMap
,设备配置,格式为 { name : { UA, width, height } }
已扩展的方法列表如下:
- exDevice(name, opts)
- exCookies(cookies, url)
- exMergeCookies(cookies)
- exScrollToTop()
- exScrollToBottom()
- exScrollToSelector(selector)
- exChangeMockStar(cookieString)
如果上述提供的扩展方法不满足您的诉求,可以选择 自定义扩展 NightmarePlus.extend(callExtend, opts) 。
nightmare 加载页面时,会产生一系列事件,具体请查看 关于页面的事件
使用 DEBUG=nightmare* node xxx.js
方式,可以打印出 nightmare 的诸多日志。