news 2026/1/13 17:08:20

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/1/7 12:20:45

LangFlow State状态模式管理生命周期

LangFlow State 状态模式管理生命周期 在构建智能对话系统或自动化任务流程时,一个常见的挑战是:如何让 AI 智能体“记住”之前的交互内容,并据此做出合理决策?尤其是在多轮对话、条件分支和动态参数传递的场景下,传统…

作者头像 李华
网站建设 2026/1/1 5:27:04

ECharts 配置语法

ECharts 配置语法详解 Apache ECharts 的配置项(option)是图表的核心,使用纯 JSON 对象格式(JavaScript 对象字面量)。它采用声明式语法:你只需描述“图表应该长什么样”,ECharts 会自动渲染。…

作者头像 李华
网站建设 2026/1/9 7:50:40

LangFlow Baidu CFC国产化替代方案测试

LangFlow Baidu CFC国产化替代方案测试 在AI应用开发日益普及的今天,如何让非技术背景的业务人员也能参与智能系统的设计,正成为企业落地大模型的关键挑战。传统基于代码的LangChain开发模式虽然灵活,但对开发者要求高、协作成本大&#xff0…

作者头像 李华
网站建设 2026/1/3 23:22:17

LangFlow CRD自定义资源定义提案

LangFlow CRD 自定义资源定义提案 在企业加速拥抱大语言模型(LLM)的今天,一个现实问题日益凸显:数据科学家能在 LangFlow 中快速拖拽出一个智能客服工作流原型,却往往需要等待数天甚至更久才能将其部署到生产环境。这中…

作者头像 李华
网站建设 2026/1/6 17:32:52

Minio开始收费了?别慌,这5种免费的分布式文件系统更香!

前言 最近,不少技术圈的朋友都在讨论一个话题:Minio是不是开始收费了? 这背后其实涉及到一个更深刻的问题——开源许可证的商业化边界。 有些小伙伴在工作中可能已经遇到了这样的困惑:公司法务审查后,认为Minio的AGPLv…

作者头像 李华
网站建设 2026/1/13 5:45:47

解锁科研“开题秘籍”:书匠策AI开题报告功能,开启学术探索新征程

在科研的浩瀚宇宙中,开题报告宛如一颗启明星,为整个研究项目指引方向。它不仅是研究者向学术界展示研究计划的重要窗口,更是确保研究具有科学性、创新性和可行性的关键环节。然而,撰写一份高质量的开题报告并非易事,从…

作者头像 李华