news 2026/6/8 22:26:25

Playwright 移动端测试

作者头像

张小明

前端开发工程师

1.2k 24
文章封面图
Playwright 移动端测试

Playwright 移动端测试(2025 年最新版)

Playwright 原生支持移动端浏览器模拟(Mobile Emulation)和真实 Android 设备测试,无需额外工具即可覆盖手机/平板场景。核心优势:一套代码跨桌面 + 移动浏览器运行,支持触屏手势、横竖屏、地理位置、设备特性等。

1.最常用方式:浏览器模拟移动设备(Emulation)

无需真实设备,速度快,适合 90% 的移动端测试场景。

在 playwright.config.ts 中定义项目

import{defineConfig,devices}from'@playwright/test';exportdefaultdefineConfig({projects:[// 桌面 Chrome{name:'Desktop Chrome',use:{...devices['Desktop Chrome']}},// iPhone 示例{name:'iPhone 14',use:{...devices['iPhone 14']}},{name:'iPhone 14 Landscape',use:{...devices['iPhone 14 landscape']}},// Android 示例{name:'Pixel 7',use:{...devices['Pixel 7']}},// iPad 示例{name:'iPad Pro',use:{...devices['iPad Pro 11']}},],});

Playwright 内置 100+ 设备模型(devices.ts 源文件),常用:

  • iPhone 13/14/15(包括 Pro/Max、landscape)
  • Pixel 5/7
  • Galaxy S23
  • iPad Air/Mini/Pro

运行移动端测试

npx playwrighttest--project="iPhone 14"# 只跑 iPhonenpx playwrighttest--project="Pixel 7"npx playwrighttest# 默认并行跑所有项目
2.测试代码示例(自动适配移动端)
import{test,expect}from'@playwright/test';test('移动端首页响应式验证',async({page})=>{awaitpage.goto('https://your-app.com');// 移动端特有:验证视口大小(自动由设备配置设置)constviewport=page.viewportSize();console.log('当前视口:',viewport);// e.g., { width: 390, height: 844 }// 验证移动端菜单(汉堡菜单)awaitexpect(page.getByRole('button',{name:'菜单'})).toBeVisible();// 模拟触屏点击(等同 click(),但更真实)awaitpage.getByRole('button',{name:'菜单'}).tap();// 模拟手势:滑动(swipe)awaitpage.touchscreen.tap(200,600);// 触摸起点awaitpage.touchscreen.touchMove(200,200);// 向上滑动// 验证横竖屏切换awaitpage.setViewportSize({width:844,height:390});// 切换到横屏awaitexpect(page.getByText('横屏布局')).toBeVisible();});
3.移动端特有功能
// 模拟地理位置test.use({geolocation:{longitude:116.397,latitude:39.909},// 北京permissions:['geolocation'],});// 模拟网络(离线/慢网)test.use({offline:true,// 离线模式// 或慢网javaScriptEnabled:true,// 自定义:通过 context 设置});// 触屏手势(touchscreen)awaitpage.touchscreen.tap(x,y);awaitpage.touchscreen.touchMove(x,y);awaitpage.touchscreen.touchEnd();// 捏合缩放(pinch zoom)awaitpage.touchscreen.touchStart(x1,y1,x2,y2);// 两指
4.真实 Android 设备测试(高级)

Playwright 支持直接连接真实 Android 手机(无需 Appium)。

前提

  • Android 设备开启 USB 调试。
  • 安装 Android SDK Platform-Tools(adb)。

配置示例

import{android}from'@playwright/test';test('真实 Android 设备',async()=>{const[device]=awaitandroid.devices();// 自动发现连接设备constcontext=awaitdevice.launchBrowser();constpage=awaitcontext.newPage();awaitpage.goto('https://your-app.com');awaitpage.screenshot({path:'real-android.png'});awaitcontext.close();});
5.最佳实践总结
  • 优先使用设备模拟(devices[‘iPhone 14’] 等),速度快、覆盖广。
  • 多项目并行:在 config 中定义多个移动设备项目,CI/CD 自动覆盖。
  • 响应式断言:根据 viewportSize() 或设备名动态断言不同布局。
  • 截图对比:移动端测试建议开启screenshot: 'on',失败时对比视觉差异。
  • 真实设备:仅在需要测试硬件特性(如摄像头、传感器)时使用。

运行示例:

npx playwrighttest--project="iPhone 14"--headed# 可视化看移动端效果

移动端测试在 Playwright 中实现非常优雅,一套代码覆盖桌面 + 多款手机/平板。官方设备列表:https://playwright.dev/docs/emulation#devices

如果需要完整响应式测试示例(如媒体查询断言)、自定义设备配置,或真实 Android 连接步骤,随时告诉我!

版权声明: 本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若内容造成侵权/违法违规/事实不符,请联系邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
网站建设 2026/6/6 7:20:52

ECharts 教程

ECharts 入门教程 ECharts(Apache ECharts)是一个由 Apache 基金会维护的开源 JavaScript 数据可视化库,它提供丰富的图表类型(如折线图、柱状图、饼图、散点图、地图等),支持高度交互和自定义&#xff0c…

作者头像 李华
网站建设 2026/6/9 19:54:19

C++使用rand生成随机数

产生 [0,b] 之间的随机数: rand()*b / RAND_MAX;产生 [-a,0] 之间的随机数: rand()*(-a) / RAND_MAX;产生 [a,b] 之间的随机数: a rand()*(b - a) / RAND_MAX;产生随机整数: v1 rand() % 100; // v1 in the range 0 to 99 v2 rand…

作者头像 李华
网站建设 2026/6/9 10:06:43

大模型系统学习:提示词工程指北

提示词工程(Prompt Engineering)作为大语言模型(Large Language Model,LLM)应用构建的一种方式被简要提及,本文将着重对该技术进行介绍。 提示词工程就是在和LLM聊天时,用来让模型回答得更好的一…

作者头像 李华
网站建设 2026/6/8 19:38:06

基于图神经网络的大规模图数据异常检测实践

图神经网络在大规模图数据异常检测中的实践:从原理到落地的完整指南 关键词 图神经网络(GNN)、大规模图数据、异常检测、图表示学习、社区发现、流式处理、分布式训练 摘要 在社交网络、金融交易、推荐系统等场景中,图数据已成为刻画复杂关系的核心结…

作者头像 李华
网站建设 2026/6/7 23:57:47

LangFlow Iterator迭代器模式遍历节点

LangFlow 中的迭代器模式:让 AI 工作流“动”起来 在构建智能应用时,我们常常需要处理一类典型任务:对一批数据重复执行相同的逻辑。比如,分析100条用户评论的情感倾向、批量生成产品描述、或多轮调用语言模型完成复杂推理。传统做…

作者头像 李华