谷歌浏览器插件 使用 playwright 回放用户动作键盘按键特殊处理方案

背景

在使用playwright 回放键盘按键的事件,官网推荐使用 press 这个 api,而实际上在回放的过程中,浏览器并没有实际执行这个按键,比如 input 里面执行回车,并没有真实触发事件,虽然 press 这个 api 执行成功了,页面却没有变化。

解决办法

我们需要模拟键盘按键事件,特别是当使用page.presselementHandle.press时,有时可能不会触发实际的事件监听(比如在输入框内按回车提交表单)。这可能是因为某些框架或自定义组件依赖于原生的键盘事件,而Playwright的press方法可能只是模拟了操作,但未完全按照真实用户的方式触发事件。

为了确保键盘事件能够被正确触发,我们可以考虑使用JavaScript来模拟更真实的键盘事件(包括keydown, keypress, keyup)。

ts 复制代码
// 使用 JS 模拟按键事件(通用方法)
async function pressWithJS(
  context: Page | Frame,
  element: ElementHandle,
  key: string,
  delay: number
): Promise<void> {
  await context.evaluate((el, { key, delay }) => {
    // 创建并派发键盘事件
    const dispatchKeyEvent = (type: string) => {
      const event = new KeyboardEvent(type, {
        key: key,
        bubbles: true,
        cancelable: true,
        view: window
      });
      el.dispatchEvent(event);
    };
    
    // 顺序派发键盘事件
    dispatchKeyEvent('keydown');
    setTimeout(() => {
      dispatchKeyEvent('keypress');
      setTimeout(() => {
        dispatchKeyEvent('keyup');
      }, delay);
    }, delay);
  }, { key, delay });
}

使用上述方法可以真实触发比如 enter 等键盘事件。

相关推荐
0思必得07 小时前
[Web自动化] Selenium处理动态网页
前端·爬虫·python·selenium·自动化
东东5168 小时前
智能社区管理系统的设计与实现ssm+vue
前端·javascript·vue.js·毕业设计·毕设
catino8 小时前
图片、文件的预览
前端·javascript
layman052810 小时前
webpack5 css-loader:从基础到原理
前端·css·webpack
半桔10 小时前
【前端小站】CSS 样式美学:从基础语法到界面精筑的实战宝典
前端·css·html
AI老李10 小时前
PostCSS完全指南:功能/配置/插件/SourceMap/AST/插件开发/自定义语法
前端·javascript·postcss
_OP_CHEN10 小时前
【前端开发之CSS】(一)初识 CSS:网页化妆术的终极指南,新手也能轻松拿捏页面美化!
前端·css·html·网页开发·样式表·界面美化
啊哈一半醒10 小时前
CSS 主流布局
前端·css·css布局·标准流 浮动 定位·flex grid 响应式布局
PHP武器库10 小时前
ULUI:不止于按钮和菜单,一个专注于“业务组件”的纯 CSS 框架
前端·css
电商API_1800790524710 小时前
第三方淘宝商品详情 API 全维度调用指南:从技术对接到生产落地
java·大数据·前端·数据库·人工智能·网络爬虫