selenium2.0滚动处理

      2016年12月15日在进行自动化测试的时候遇到了一个问题:

      获取定位在屏幕外的元素单击事件会因置顶导航栏随滚动条移动从而被挡住无法点击,如图1-3

  selenium2.0滚动处理_第1张图片

图(1)

 selenium2.0滚动处理_第2张图片

图(2)

 selenium2.0滚动处理_第3张图片

图(3)

            此时我们就要用到原生js事件调用滚动条,此时我是用

((JavascriptExecutor)driver).executeScript("arguments[0].scrollIntoView(false);",driver.findElement(By.xpath("//a[@cartname='allsort-addCart0']"))); 

             这里的scrollIntoView值为false意思为当这个元素出现在底部时,就停止滚动!后面""里则是要绑定的元素,此时我们就能执行单击事件啦!

           下面则是基于selenium2.0的自动化测试调用滚动条的其他用法

//移动到元素e对象的“顶端”与当前窗口的“顶部”对齐  
((JavascriptExecutor) driver).executeScript("arguments[0].scrollIntoView();", e);  
((JavascriptExecutor) driver).executeScript("arguments[0].scrollIntoView(true);", e);  
  
//移动到元素e对象的“底端”与当前窗口的“底部”对齐  
((JavascriptExecutor) driver).executeScript("arguments[0].scrollIntoView(false);", e);  
  
//移动到页面最底部  
((JavascriptExecutor) driver).executeScript("window.scrollTo(0, document.body.scrollHeight)");  

//移动到窗口绝对位置坐标,如下移动到纵坐标600像素位置  
((JavascriptExecutor) driver).executeScript("window.scrollTo(0, 600)");  
 Thread.sleep(3000);  
//结合上面的scrollTo语句,仍然移动到纵坐标200像素位置  
((JavascriptExecutor) driver).executeScript("window.scrollTo(0, 200)"); 

//移动到指定的坐标(相对当前的坐标移动)
((JavascriptExecutor) driver).executeScript("window.scrollBy(0, 500)"); Thread.sleep(1000);
//结合上面的scrollBy语句,相当于移动到500+100=600像素位置
((JavascriptExecutor) driver).executeScript("window.scrollBy(0, 100)");
 
 

你可能感兴趣的:(selenium2.0)