Puppeteer - 设备模拟



我们可以在 Puppeteer 中使用移动设备配置运行测试,并检查网页的响应式特性。Puppeteer 支持的设备列表可以从 Chrome DevTools 中获取。在 Chrome 浏览器中打开的页面上右键点击,然后选择“检查”。

Select Inspect

然后,点击“切换设备工具栏”。

Toggle Device Toolbar

点击下拉菜单 - “响应式”以获取设备列表。

Responsive

要模拟设备,我们必须使用 emulate() 方法,并将要模拟的设备作为参数传递给此方法。此方法的语法如下:

const m = puppeteer.devices['iPhone X']
//emulate iPhoneX
await page.emulate(m)

让我们使用 Puppeteer 中的 emulate 函数模拟 iPhone X 设备。

首先,请按照 Puppeteer 基本测试章节中的步骤 1 到 2 操作,步骤如下:

步骤 1 - 在创建 node_modules 文件夹的目录中创建一个新文件(Puppeteer 和 Puppeteer 核心已安装的位置)。

Puppeteer 安装的详细信息在 Puppeteer 安装章节中进行了讨论。

右键点击创建 node_modules 文件夹的文件夹,然后点击“新建文件”按钮。

Node Modules

步骤 2 - 输入文件名,例如 testcase1.js。

Testcase1.JS

步骤 3 - 将以下代码添加到创建的 testcase1.js 文件中。

//Puppeteer library
const puppeteer = require('puppeteer')
//launch browser in headed mode
puppeteer.launch({headless:false}).then(async browser => {
   //browser new page
   const page = await browser.newPage()
   //set device to iPhone X
   const m = puppeteer.devices['iPhone X']
   //emulate iPhoneX
   await page.emulate(m)
   //launch URL
   await page.goto('https://tutorialspoint.com/index.htm')
   //capture screenshot of emulated device
   await page.screenshot({ path: 'iPhoneDevice.png'})
   //browser close
   await browser.close()
})

步骤 4 - 使用以下命令执行代码:

node <filename>

因此,在我们的示例中,我们将运行以下命令:

node testcase1.js
Iphone Device

命令成功执行后,在页面目录中会创建一个名为 iPhoneDevice.png 的新文件。它包含 iPhone X 设备模拟网页的捕获屏幕截图。

广告