本節(jié)重點:
控制滾動條到底部
有時候我們需要控制頁面滾動條上的滾動條,但滾動條并非頁面上的元素,這個時候需要借助js是來進行操作。一般用到操作滾動條的會兩個場景:
注冊時的法律條文需要閱讀,判斷用戶是否閱讀的標準是:滾動條是否拉到下方。
要操作的頁面元素不在吸視范圍,無法進行操作,需要拖動滾動條
其實,實現(xiàn)這個功能只要一行代碼,但由于不懂js ,所以花了不小力氣找到這種方法。
用于標識滾動條位置的代碼
<body onload= "document.body.scrollTop=0 ">
<body onload= "document.body.scrollTop=100000 ">
如果滾動條在上方的話,scrollTop=0 ,那么要想使用滾動條在可下方,可以scrollTop=100000 ,這樣可以使?jié)L動條在下方。
場景一
先來解決場第一個問題,法律條款是一個內(nèi)嵌窗口,通過firebug工具可以定位到內(nèi)嵌入窗口可以定位到元素的id ,可以通過下面的代碼實現(xiàn)。
js="var q=document.getElementById('id').scrollTop=10000"
driver.execute_script(js)
注:由于沒找到合適的例子,所沒驗證,從參考資料來看這種寫法應該沒問題,如有請反饋。
場景二
有滾動條的頁面到處可見,這個比較容易找例子,我們以操作百度搜索結(jié)果頁為例:
#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()