您的位置:软件测试 > 开源软件测试 > 开源功能测试工具 > Selenium
轻松自动化---selenium-webdriver(python) (十一)
作者:网络转载 发布时间:[ 2013/9/9 10:18:24 ] 推荐标签:

  本节重点:

  控制滚动条到底部

  有时候我们需要控制页面滚动条上的滚动条,但滚动条并非页面上的元素,这个时候需要借助js是来进行操作。一般用到操作滚动条的会两个场景:

  注册时的法律条文需要阅读,判断用户是否阅读的标准是:滚动条是否拉到下方。

  要操作的页面元素不在吸视范围,无法进行操作,需要拖动滚动条

  其实,实现这个功能只要一行代码,但由于不懂js ,所以花了不小力气找到这种方法。

  用于标识滚动条位置的代码

  <body   onload= "document.body.scrollTop=0 ">

  <body   onload= "document.body.scrollTop=100000 ">

  如果滚动条在上方的话,scrollTop=0 ,那么要想使用滚动条在可下方,可以scrollTop=100000 ,这样可以使滚动条在下方。

  场景一

  先来解决场第一个问题,法律条款是一个内嵌窗口,通过firebug工具可以定位到内嵌入窗口可以定位到元素的id ,可以通过下面的代码实现。

  js="var q=document.getElementById('id').scrollTop=10000"

  driver.execute_script(js)

  注:由于没找到合适的例子,所没验证,从参考资料来看这种写法应该没问题,如有请反馈。

  场景二

  有滚动条的页面到处可见,这个比较容易找例子,我们以操作百度搜索结果页为例:

#coding=utf-8
from selenium import webdriver
import time

#访问百度
driver=webdriver.Firefox()
driver.get(http://www.baidu.com)

#搜索
driver.find_element_by_id("kw").send_keys("selenium")
driver.find_element_by_id("su").click()
time.sleep(3)

#将页面滚动条拖到底部
js="var q=document.documentElement.scrollTop=10000"
driver.execute_script(js)
time.sleep(3)


#将滚动条移动到页面的顶部
js="var q=document.documentElement.scrollTop=0"
driver.execute_script(js)
time.sleep(3)

driver.quit()

相关链接:
软件测试工具 | 联系我们 | 投诉建议 | 诚聘英才 | 申请使用列表 | 网站地图
沪ICP备07036474 2003-2017 版权所有 上海泽众软件科技有限公司 Shanghai ZeZhong Software Co.,Ltd