zombie 试用

以前有大概介绍过zombie,以下是一个简单的试用

环境准备

  • nodejs 项目
yarn init -y
  • npm scirpt
{
  "name": "second",
  "version": "1.0.0",
  "main": "index.js",
  "license": "MIT",
  "dependencies": {
    "zombie": "^6.1.4"
  },
  "scripts": {
    "start": "node app.js"
  }
}
  • app.js
const Browser = require('zombie');
const browser = new Browser();
browser.visit('https://www.baidu.com/', function() {
  const value = browser.window.document
  console.log(value.body.innerHTML);
});

运行&&效果

  • 运行
yarn start
  • 效果

从以下图片可以看出zombie更好的模拟了浏览器的处理,加载了需要的资源

 

 

说明

zombie 能帮助我们模拟大部分请求,但是也有一些场景可能不行(不如卡住,或者异常)出现类似问题,我们可以开启调试模式
如下,查看请求

 
{
  "name": "second",
  "version": "1.0.0",
  "main": "index.js",
  "license": "MIT",
  "dependencies": {
    "zombie": "^6.1.4"
  },
  "scripts": {
    "start": "DEBUG=* node app.js"
  }
}

zombie 提供的api
Browser包含了断言以及一些dom 相关的api,可以方便我们操作dom
Assertions 提供的比较完整的断言处理
Cookies,提供了访问cookie 的能力
Tabs 提供了类似chrome 的tab 管理能力
Debugging 提供了调试能力
Events 提供了事件机制,我们可以处理浏览器的事件
Resources 提供资源的管理能力,html,js,xhr 请求
Pipeline 实现pipeline 模式的数据处理

参考资料

https://github.com/assaf/zombie

posted on   荣锋亮  阅读(288)  评论(0编辑  收藏  举报

编辑推荐:
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· 没有源码,如何修改代码逻辑?
阅读排行:
· 全程不用写代码,我用AI程序员写了一个飞机大战
· DeepSeek 开源周回顾「GitHub 热点速览」
· 记一次.NET内存居高不下排查解决与启示
· MongoDB 8.0这个新功能碉堡了,比商业数据库还牛
· .NET10 - 预览版1新功能体验(一)
历史上的今天:
2019-06-01 hasura skor 一个pg 的event trigger 扩展
2019-06-01 callbag js callback 标准-支持轻量级观测以及迭代
2019-06-01 一篇来自hasura graphql-engine 百万级别live query 的实践
2019-06-01 hasura graphql-engine 最近版本的一些更新
2019-06-01 urql 高度可自定义&&多功能的react graphql client
2018-06-01 ballerina 学习二十二 弹性服务
2018-06-01 ballerina 学习二十一 http2

导航

< 2025年3月 >
23 24 25 26 27 28 1
2 3 4 5 6 7 8
9 10 11 12 13 14 15
16 17 18 19 20 21 22
23 24 25 26 27 28 29
30 31 1 2 3 4 5
点击右上角即可分享
微信分享提示