selenium---JS处理滚动条

  在web自动化中,会遇到想要定位的内容,因为电脑分辨率的问题致使,须要定位的元素可能没有在页面上展现出来,这个时候咱们应该怎么作呢?正常状况下,确定是点击滚动条,找到想要的元素,而后进行操做。问题来了,selenium有没有办法操做滚动呢?selenium目前没有好的办法进行操做滑动条,可是前面介绍的JS有这个功能哈web

滚动条

滚动条:滚动条是在咱们使用软件没法显示整个界面的时候,右侧的一个能够滚动的用于显示剩下界面的条spa

知道了滚动条是什么,那么咱们如何经过JS进行操做呢?code

JS操做滚动条

JS操做滚动条有几种blog

一、滚动条到顶部

# JS滚动条到顶部
js="var q=document.getElementById('id').scrollTop=0"

二、滚动条在底部,scrollTop表示滑动条的位置

# 滚动条到底部,
js="var q=document.documentElement.scrollTop=10000"

三、操做横向滚动条

# 操做横向滚动条
js  = “window.scrollTo(100,400)“

四、经过元素进行滚动

经过观察会发现上面的滚动条都是滚动到固定位置,那么咱们的元素在中间,咱们又不清楚滚动条具体停放在哪里?咱们能够经过JS进行找到这个元素而后将滚动条操做到可见元素的位置ip

# 滚动到元素可见位置
js = "arguments[0].scrollIntoView()"
# 元素位置
element = driver.find_element_by_id('xxxx')
# 滚动可见位置
driver.execute_script(js,element)

小试牛刀

这里安静就拿博客园来举例子,经过元素进行滚动到可视区域element

from selenium import webdriver
import time
driver = webdriver.Chrome()
driver.get('https://www.cnblogs.com/qican/')
# 找到想要滚动到的元素
element = driver.find_element_by_xpath('//*[contains(text(),"下一页")]')
# js操做脚本
js = "arguments[0].scrollIntoView()"
driver.execute_script(js,element)
time.sleep(2)
element.click()

 

其实经过JS操做web页面的内容还有不少,JS能够帮助咱们解决一些selenium没法解决的问题,后续一点点的为你们补充JS工做中遇到的内容,你们也能够留言说说你在工做中经过JS都作哪些?get