通常的日期控件都是input标签下弹出来的,设置日期使用selenium中的sendKeys 方法就能够解决。css
可是咱们也会碰到下面的时间日期控件(这个时候这个文本框是不容许咱们输入时间的)如图:html
这个时候,无法调用WebElement的sendKeys(),像这种选择时间的input标签都会有一个readonly属性,这个时候咱们就只能选择时间,不能手动输入,那么这种状况,咱们该怎么处理呢?spa
具体代码示例以下:code
/** * 经过JS选择日期 */ @Test public void testByJs() { driver.get("https://huoche.cncn.com/train-%B4%F3%C1%AC-%C9%F2%D1%F4"); driver.manage().window().maximize(); JavascriptExecutor removeAttribute = (JavascriptExecutor) driver; //remove readonly attribute removeAttribute.executeScript("var setDate=document.getElementById(\"date\").removeAttribute('readonly');"); //输入要输入日期 driver.findElement(By.id("date")).clear(); driver.findElement(By.id("date")).sendKeys("2019-08-31"); //点击查询 driver.findElement(By.id("searchBtn")).click(); //获取输入后日期显示 String value = driver.findElement(By.id("date")).getAttribute("value"); //验证日期是否为选中的8月31日 Assert.assertEquals(value,"2019-08-31"); }
具体代码示例以下:htm
/** * 经过Iframe选择日期 */ @Test public void testByIframe() { driver.get("https://huoche.cncn.com/train-%B4%F3%C1%AC-%C9%F2%D1%F4"); driver.manage().window().maximize(); //点击日历控件 driver.findElement(By.id("date")).click(); //iframe框 WebElement iframe = driver.findElement(By.cssSelector("[src='about\\:blank']")); //进入日历控件中操做 driver.switchTo().frame(iframe); //选择31号即月末 driver.findElement(By.xpath("//tr/td[@onclick='day_Click(2019,8,31);']")).click(); //跳出日历控件操做 driver.switchTo().defaultContent(); //点击查询 driver.findElement(By.id("searchBtn")).click(); //获取输入后日期显示 String value = driver.findElement(By.id("date")).getAttribute("value"); //验证日期是否为选中的8月31日 Assert.assertEquals(value,"2019-08-31"); }
以上两种方法,均可实现选择日期操做,仅供参考,若是以为好,能够关注我哦blog
原文出处:https://www.cnblogs.com/longronglang/p/11327327.htmlip