谷歌浏览器插件 使用 playwright 回放slide 拖动动作

背景

在 Playwright 中需要模拟比如 Element UI 组件库中滑块组件的滑动操作,可以通过下面方式实现。Element UI 的滑块组件通常由轨道(track)、滑块按钮(thumb)和进度条(bar)组成,我们需要定位滑块按钮并模拟拖动操作。

解决方案

模拟鼠标事件实现精确控制

js 复制代码
import { chromium } from 'playwright';

(async () => {
  const browser = await chromium.launch();
  const page = await browser.newPage();
  await page.goto('https://your-elementui-page.com');
  
  const sliderThumb = page.locator('.el-slider__button');
  const sliderTrack = page.locator('.el-slider__runway');
  
  // 获取轨道尺寸和位置
  const trackBox = await sliderTrack.boundingBox();
  if (!trackBox) throw new Error('Slider track not found');
  
  // 计算目标位置(示例:拖动到 75% 位置)
  const targetX = trackBox.x + trackBox.width * 0.75;
  const targetY = trackBox.y + trackBox.height / 2;
  
  // 模拟完整拖拽过程
  await sliderThumb.hover();
  await page.mouse.down();
  // 添加微小偏移避免直接跳转
  await page.mouse.move(targetX + 10, targetY, { steps: 5 });
  // 精确移动到目标位置
  await page.mouse.move(targetX, targetY, { steps: 20 });
  await page.mouse.up();
  
  // 验证结果(示例)
  const sliderValue = await page.locator('.el-slider__input input').inputValue();
  console.log('Final slider value:', sliderValue);
  
  await browser.close();
})();

关键点说明:

  1. 定位元素

    • 滑块按钮:.el-slider__button
    • 滑动轨道:.el-slider__runway
    • 值输入框(可选):.el-slider__input input
  2. 计算位置

    • 使用 boundingBox() 获取元素位置和尺寸
    • 通过百分比计算目标坐标:targetX = track.x + track.width * (percentage/100)
  3. 拖动技巧

    • 手动 mouse.down() → move() → up() 可实现更精细控制
    • 添加 steps 参数使移动更平滑(模拟真人操作)
  4. 注意事项

    • 使用 waitForSelector 确保组件加载完成
    • 根据实际页面结构调整选择器
相关推荐
天蓝色的鱼鱼4 分钟前
你的项目真的需要SSR吗?还是只是你的简历需要?
前端·架构
恋猫de小郭31 分钟前
移动端开发稳了?AI 目前还无法取代客户端开发,小红书的论文告诉你数据
前端·flutter·ai编程
文心快码BaiduComate1 小时前
百度云与光本位签署战略合作:用AI Agent 重构芯片研发流程
前端·人工智能·架构
闲云一鹤1 小时前
nginx 快速入门教程 - 写给前端的你
前端·nginx·前端工程化
QCY2 小时前
「完全理解」1 分钟实现自己的 Coding Agent
前端·agent·claude
一拳不是超人2 小时前
Electron主窗口弹框被WebContentView遮挡?独立WebContentView弹框方案详解!
前端·javascript·electron
anyup2 小时前
🔥2026最推荐的跨平台方案:H5/小程序/App/鸿蒙,一套代码搞定
前端·uni-app·harmonyos
雮尘3 小时前
如何在非 Claude IDE (TARE、 Cursor、Antigravity 等)下使用 Agent Skills
前端·agent·ai编程
icebreaker3 小时前
Weapp-vite:原生模式之外,多一种 Vue SFC 选择
前端·vue.js·微信小程序
icebreaker3 小时前
重走 Vue 长征路 Weapp-vite:编译链路与 Wevu 运行时原理拆解
前端·vue.js·微信小程序