《刚刚问世》系列初窥篇-Java+Playwright自动化测试-20- 操作鼠标拖拽 - 上篇(详细教程)

embedded/2025/2/13 17:12:40/
htmledit_views">

1.简介

本文主要介绍两个在测试过程中可能会用到的功能:在selenium中宏哥介绍了Actions类中的拖拽操作和Actions类中的划取字段操作。例如:需要在一堆log字符中随机划取一段文字,然后右键选择摘取功能。playwright同样可以实现元素的拖拽和释放的操作。

2.拖拽操作

鼠标拖拽操作,顾名思义就是:就是鼠标按住将一个元素拖拽到另一个元素上。拖拽是指将某个元素从一个位置拖动到另一个位置。为了模拟这种操作,Playwright 提供了 DragToAsync 方法,它可以帮助我们轻松地完成拖拽功能。

2.1基础知识

1.按住元素从页面的一个位置拖动到另外一个位置,有2种方式可以实现:

  • locator.dragTo(target: locator) 先定位元素,调用drag_to方法到目标元素
  • page.dragAndDrop(source: str, target: str) page对象直接调用

2.拖动和释放操作

page.dragAndDrop可以实现通过page对象调用dragAndDrop ,部分源码如下:

html" title=java>java">/*** This method drags the source element to the target element. It will first move to the source element, perform a {@code* mousedown}, then move to the target element and perform a {@code mouseup}.** <p> **Usage*** <pre>{@code* page.dragAndDrop("#source", '#target');* // or specify exact positions relative to the top-left corners of the elements:* page.dragAndDrop("#source", '#target', new Page.DragAndDropOptions()*   .setSourcePosition(34, 7).setTargetPosition(10, 20));* }</pre>** @param source A selector to search for an element to drag. If there are multiple elements satisfying the selector, the first will be* used.* @param target A selector to search for an element to drop onto. If there are multiple elements satisfying the selector, the first will* be used.* @since v1.13*/default void dragAndDrop(String source, String target) {dragAndDrop(source, target, null);}/*** This method drags the source element to the target element. It will first move to the source element, perform a {@code* mousedown}, then move to the target element and perform a {@code mouseup}.** <p> **Usage*** <pre>{@code* page.dragAndDrop("#source", '#target');* // or specify exact positions relative to the top-left corners of the elements:* page.dragAndDrop("#source", '#target', new Page.DragAndDropOptions()*   .setSourcePosition(34, 7).setTargetPosition(10, 20));* }</pre>** @param source A selector to search for an element to drag. If there are multiple elements satisfying the selector, the first will be* used.* @param target A selector to search for an element to drop onto. If there are multiple elements satisfying the selector, the first will* be used.* @since v1.13*/void dragAndDrop(String source, String target, DragAndDropOptions options);

注:source 和 target 是字符串格式,也就是传selector 选择器的方法

3.拖拽操作

locator.drag_to()可以实现拖放操作,该操作将:

  • 将鼠标悬停在要拖动的元素上
  • 按鼠标左键
  • 将鼠标移动到将接收放置的元素
  • 松开鼠标左键

语法示例:

html" title=java>java">page.locator("#item-to-be-dragged").dragTo(page.locator("#item-to-drop-at"));

4.手工拖拽

如果要精确控制拖动操作,请使用locator.hover()、mouse.down()、mouse.move()和mouse.up()等较低级别的方法。

语法示例:

html" title=java>java">page.locator("#item-to-be-dragged").hover();
page.mouse().down();
page.locator("#item-to-drop-at").hover();
page.mouse().up();

敲黑板!!!注意:

如果你的页面依赖于被 dispatch 的事件,你需要至少两次鼠标移动才能在所有浏览器中触发它。要可靠地发出第二次鼠标移动,请重复两次mouse.move()或Locator.hover()。操作顺序为:将拖动元素悬停,鼠标向下,将拖放元素悬停,第二次悬停拖放元素,鼠标向上。

3.牛刀小试

学习过Playwright的拖拽基础知识后,我们趁热打铁将其实践一下,以为我们更好的理解和记忆。宏哥这里JqueryUI网站的一个拖拽demo实战一下。

3.1拖拽操作

使用locator.dragTo()执行拖放操作,实现自动化测试。

3.1.1代码设计

3.1.2参考代码
html" title=java>java">package com.bjhg.playwright;import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserContext;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;/*** @author 北京-宏哥* * @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)* * 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-20-操作鼠标拖拽 -上篇(详细教程)** 2025年02月12日*/
public class Test_DragAndDrop {public static void main(String[] args) {try (Playwright playwright = Playwright.create()) {//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(3000));//2.创建contextBrowserContext context = browser.newContext();//创建pagePage page = context.newPage();//3.浏览器访问demopage.navigate("https://jqueryui.com/resources/demos/droppable/default.html");//4.开始拖拽page.locator("#draggable").dragTo(page.locator("#droppable"));System.out.println("Test Pass");//关闭pagepage.close();//关闭browserbrowser.close();}}
}
3.1.3运行代码

1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(拖拽过去后,背景颜色发生变化)。如下图所示:

3.2拖动和释放操作

使用page.dragAndDrop(locator, loacator),实现自动化测试。

3.2.1代码设计

3.2.2参考代码
html" title=java>java">package com.bjhg.playwright;import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserContext;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;/*** @author 北京-宏哥* * @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)* * 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-20-操作鼠标拖拽 -上篇(详细教程)** 2025年02月12日*/
public class Test_DragAndDrop {public static void main(String[] args) {try (Playwright playwright = Playwright.create()) {//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(3000));//2.创建contextBrowserContext context = browser.newContext();//创建pagePage page = context.newPage();//3.浏览器访问demopage.navigate("https://jqueryui.com/resources/demos/droppable/default.html");//4.开始拖拽//page.locator("#draggable").dragTo(page.locator("#droppable"));page.dragAndDrop("#draggable", "#droppable");System.out.println("Test Pass");//关闭pagepage.close();//关闭browserbrowser.close();}}
}
3.2.3运行代码

1.运行代码,右键Run As->Java Application,就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(拖拽过去后,背景颜色发生变化)。如下图所示:

3.3手工拖拽

想精确控制拖动操作,可以使用较低级别的手工方法,如locator.hover()、mouse.down()、mouse.move()和mouse.up()。来实现自动化测试。

3.1代码设计

3.2参考代码
html" title=java>java">package com.bjhg.playwright;import com.microsoft.playwright.Browser;
import com.microsoft.playwright.BrowserContext;
import com.microsoft.playwright.BrowserType;
import com.microsoft.playwright.Page;
import com.microsoft.playwright.Playwright;/*** @author 北京-宏哥* * @公众号:北京宏哥(微信搜索,关注宏哥,提前解锁更多测试干货)* * 《刚刚问世》系列初窥篇-Java+Playwright自动化测试-20-操作鼠标拖拽 -上篇(详细教程)** 2025年02月12日*/
public class Test_DragAndDrop {public static void main(String[] args) {try (Playwright playwright = Playwright.create()) {//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(3000));//2.创建contextBrowserContext context = browser.newContext();//创建pagePage page = context.newPage();//3.浏览器访问demopage.navigate("https://jqueryui.com/resources/demos/droppable/default.html");//4.开始拖拽//page.locator("#draggable").dragTo(page.locator("#droppable"));//page.dragAndDrop("#draggable", "#droppable");page.locator("#draggable").hover();page.mouse().down();page.locator("#droppable").hover();page.mouse().up();System.out.println("Test Pass");//关闭pagepage.close();//关闭browserbrowser.close();}}
}
3.3运行代码

1.运行代码,右键Run'Test',就可以看到控制台输出,如下图所示:

2.运行代码后电脑端的浏览器的动作(拖拽过去后,背景颜色发生变化)。如下图所示:

4.小结

宏哥由于网络的原因,有时可以访问到jquery UI的网页的demo,有时又不可以,在网上找了半天给小伙伴们或者童鞋们又找到一个网址:Sahi Tests 里边有很多在线免费的demo供大家学习使用。有兴趣的同学可以找到里边的拖拽demo来巩固一下今天学习的知识。其实你会发现是很简单的。经过这么久的分享和介绍宏哥发现Java语言的单引号和双引号在playwright中是有区别的,详细区别宏哥就不做赘述,感兴趣的可以自己自行查询资料,小伙伴或者童鞋们要注意哦!


http://www.ppmy.cn/embedded/161911.html

相关文章

Java面试——Tomcat

优质博文&#xff1a;IT_BLOG_CN 一、Tomcat 顶层架构 Tomcat中最顶层的容器是Server&#xff0c;代表着整个服务器&#xff0c;从上图中可以看出&#xff0c;一个Server可以包含至少一个Service&#xff0c;用于具体提供服务。Service主要包含两个部分&#xff1a;Connector和…

android studio下载安装汉化-Flutter安装

1、下载android studio官方地址&#xff1a;&#xff08;这个网址可能直接打不开&#xff0c;需要VPN&#xff09; https://developer.android.com/studio?hlzh-cn mac版本分为X86和arm版本&#xff0c;电脑显示芯片是Inter的就是x86的&#xff0c;显示m1和m2的就是arm的 …

Docker 部署 MYSQL-5.7 主从

一、拉取对应镜像 docker pull registry.cn-hangzhou.aliyuncs.com/farerboy/mysql:5.7 二、部署主节点 1、创建对应需要的目录 mkdir -p /wwwroot/opt/docker/mysql-master-3306/log mkdir -p /wwwroot/opt/docker/mysql-master-3306/data mkdir -p /wwwroot/opt/docker/m…

DeepSeek 深度解析:引领 SEO 与数据分析新时代的智能工具

DeepSeek 深度解析&#xff1a;引领 SEO 与数据分析新时代的智能工具 &#x1f680; 在当今数字化时代&#xff0c;网站排名与数据驱动的决策对企业发展至关重要。如何在激烈的市场竞争中精准捕捉用户需求、优化内容策略&#xff1f;答案可能就在 DeepSeek 中。本文将从核心理…

瑞熙贝通实验室安全综合管理平台更新迭代v4.0产品介绍

随着科研事业的蓬勃发展&#xff0c;科研实验室是高校科研的重要场所 &#xff0c;是培养学生科研能力、进行科学实验、创造科研成果的重要基地。然而&#xff0c;实验室也存在诸多安全隐患&#xff0c;如化学品泄露、火灾、设备故障、中毒、辐射、窒息等&#xff0c;这些都可能…

vscode插件Remote - SSH使用教程

Remote - SSH 是一款非常实用的 Visual Studio Code (VSCode) 扩展插件,它允许开发者通过SSH连接到远程服务器,并像在本地一样进行代码编辑和调试。这意味着你可以直接在VS Code中打开位于远程机器上的文件夹,并利用本地安装的VS Code功能,如语法高亮、智能感知、Git集成等…

AI时代的前端工程师:机遇与挑战

在飞速发展的科技浪潮中&#xff0c;人工智能&#xff08;AI&#xff09;技术正以前所未有的速度改变着我们的生活。从智能家居到自动驾驶&#xff0c;AI 的触角已经伸向各行各业&#xff0c;而作为互联网应用的基石——前端开发领域&#xff0c;也正经历着AI带来的深刻变革。本…

02、QLExpress从入门到放弃,相关API和文档

QLExpress从入门到放弃,相关API和文档 一、属性开关 public class ExpressRunner {private boolean isTrace;private boolean isShortCircuit;private boolean isPrecise; }/*** 是否需要高精度计算*/ private boolean isPrecise false;高精度计算在会计财务中非常重要&…