当前位置: 首页 > news >正文

《刚刚问世》系列初窥篇-Java+Playwright自动化测试-31- 操作日历时间控件-上篇(详细教程) - 北京

1.简介

我们在实际工作或者生活中,有可能遇到有些web产品,网页上有一些时间选择,然后支持按照不同时间段范围去筛选数据,例如:我们预定火车票或者预定酒店,需要选择发车日期或者酒店的入住与退房时间。宏哥早在之前的12306选出发站就简单的提到过,只不过是一带而过,今天就展开详细介绍一下。网页上日历控件一般,是一个文本输入框,鼠标点击,就会弹出日历界面,可以选择具体日期。这一篇,宏哥就来介绍一下日历控件是如何用Playwright实现自动化。

2.JQueryUI网站

2.1被测网址

1.被测网址的地址:

 https://jqueryui.com/resources/demos/checkboxradio/default.html

2.网页如下图:

GIF 2025-7-31 16-03-56

3.方法一

宏哥这里提供两种方法,其他的基本上都是围绕这两种方法进行拆解和处理的。第一种方法:比较简单直接将日历控件看作是文本输入框,直接按照日期格式输入就可以了(马上国庆节了,宏哥直接输入25年的国庆节,这种方式还是比较简单容易上手的)。

3.1代码设计

根据第一种思路进行代码设计如下图所示:

image

3.2参考代码

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自动化测试-31- 操作日历时间控件-上篇** 2025年08月04日*/public class Test_calendar {public static void main(String[] args) {// TODO Auto-generated method stubtry (Playwright playwright = Playwright.create()) {//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(300));//2.创建contextBrowserContext context = browser.newContext();//创建pagePage page = context.newPage();//3.浏览器访问demopage.navigate("http://jqueryui.com/resources/demos/datepicker/default.html");Thread.sleep(100);//4.定位日历的输入框,并输入国庆节:2025-10-01page.locator("#datepicker").fill("2025-10-01");System.out.println("Test Pass");//5.关闭page
            page.close();//6.关闭browser
            browser.close();} catch (InterruptedException e) {// TODO Auto-generated catch block
            e.printStackTrace();}}
}

3.3运行代码

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

image

2.运行代码后电脑端的浏览器的动作(日期控件的输入框直接输入国庆节,看不清的小伙伴或者童鞋们可以自己在关闭浏览器前加一个等待即可)。如下图所示:

GIF+2025-7-31+15-38-05

4.方法二

第二种方法:一种笨办法,通过元素定位,采用编写的Java脚本模拟手工操作一样,将日期一步一步选择点击出来。

4.1代码设计

根据第二种思路进行代码设计如下图所示:

image

4.2参考代码

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自动化测试-31- 操作日历时间控件-上篇** 2025年08月04日*/public class Test_calendar {public static void main(String[] args) {// TODO Auto-generated method stubtry (Playwright playwright = Playwright.create()) {//1.使用chromium浏览器,# 浏览器配置,设置以GUI模式启动Chrome浏览器(要查看浏览器UI,在启动浏览器时传递 headless=false 标志。您还可以使用 slowMo 来减慢执行速度。Browser browser = playwright.chromium().launch(new BrowserType.LaunchOptions().setHeadless(false).setSlowMo(500));//2.创建contextBrowserContext context = browser.newContext();//创建pagePage page = context.newPage();//3.浏览器访问demopage.navigate("http://jqueryui.com/resources/demos/datepicker/default.html");Thread.sleep(100);//4.定位日历的并点击输入框,page.locator("#datepicker").click();//点击下一个月8月,因为宏哥是7月份写的,所有需要点击到10月份page.locator("//*[@id='ui-datepicker-div']/div/a[@data-handler='next']").click();    //点击下一个月9月page.locator("//*[@id='ui-datepicker-div']/div/a[@data-handler='next']").click();//点击下一个月10月page.locator("//*[@id='ui-datepicker-div']/div/a[@data-handler='next']").click();//xpath定义第二行第六个元素,可能每个月排序不一样,所以不一定点击的就是01日(2025-10-01)page.locator("//*[@id='ui-datepicker-div']/table/tbody/tr[1]/td[4]/a").click();System.out.println("Test Pass");//5.关闭page
            page.close();//6.关闭browser
            browser.close();} catch (InterruptedException e) {// TODO Auto-generated catch block
            e.printStackTrace();}}
}

4.3运行代码

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

image

2.运行代码后电脑端的浏览器的动作(日期控件的输入框直接输入国庆节)。如下图所示:

GIF+2025-7-31+15-57-31

5.小结

日历控件的自动化测试操作今天就先介绍讲解到这里,比较简单易懂。希望对您有所帮助或者参考。好了,今天时间不早了,灰常感谢您耐心地阅读!!!

http://www.jsqmd.com/news/27146/

相关文章:

  • 2025年评价高的WHB系列筛土机最新TOP品牌厂家排行
  • 2025年企业级制品库选型指南:国产化替代与高效协同新选择
  • 前端入门资料
  • 2025年口碑好的碳钢超微粉碎机厂家推荐及采购指南
  • keycloak~关于iframe方式对接keyclock的注意事项
  • 25.09.22
  • 25.10.16
  • 25.10.10
  • 25.10.06
  • 25.10.03
  • 四个月,AI为主,人为辅,一款产品两个知识库!
  • 25.09.17
  • 政府机构跨网文件交换案例分享:构建跨网文件交换统一通道
  • 25.09.15
  • 2025年优秀的煤炭化验设备最新TOP厂家排名
  • P10281 [USACO24OPEN] Grass Segments G
  • 2025年诚信的316L不锈钢带最新TOP厂家排名
  • Java 类加载机制 面试题(一)
  • 2025年优秀的舟山注塑螺杆厂家最新推荐排行榜
  • 2025年专业的工业型无线测力称重变送器高评价厂家推荐榜
  • C# Avalonia 17- ControlTemplates - GradientButtonTest
  • 2025年专业的液压式矫平机优质厂家推荐榜单
  • KMP 学习笔记
  • CentOS7进入单用户模式
  • 实例方法实际上也是类属性,这个说法对吗?——实例的命名空间和类的命名空间详解
  • 2025年靠谱的升降机TOP实力厂家推荐榜
  • CSP-S 2025游寄
  • 2025 年洗碗机厂家最新推荐榜,技术实力与市场口碑深度解析,筛选高品质设备制造企业长龙式 / 揭盖式 / 通道式洗碗机厂家推荐
  • 2025年诚信的转轮式热回收空调机组最新TOP厂家排名
  • 2025年热门的五金铰链厂家选购指南与推荐