selenium之 如何控制网页内嵌div中滚动条的滚动

更多关于python selenium的文章,请关注我的专栏:Python Selenium自动化测试详解


很多人疑惑怎么用selenium控制网页div中滚动条的滚动,其实这个问题很简单,用JS很简单就可以实现。
示例HTML代码如下:

<!DOCTYPE html>
<html>
<head>
<style type="text/css">
div.scroll
{
background-color:#00FFFF;
width:100px;
height:100px;
overflow:auto;
}

</style>
</head>

<body>

<p>overflow:scroll</p>
<div class="scroll">You can use the overflow property when you want to have better control of the layout. The default value is visible.aaaaaaaaaaaaaaaaaaaaaaaaaaaa</div>

</body>
</html>

接下来我们用JS来控制里面的滚动条滚动:

from selenium import webdriver
dr=webdriver.Firefox()
dr.get('file:///D:/1.html')
js='document.getElementsByClassName("scroll")[0].scrollTop=10000' 
# 就是这么简单,修改这个元素的scrollTop就可以
dr.execute_script(js)

当然,我们能做更多:

document.getElementsByClassName("scroll")[0].scrollHeight # 获取滚动条高度
document.getElementsByClassName("scroll")[0].scrollWidth # 获取横向滚动条宽度
document.getElementsByClassName("scroll")[0].scrollLeft=xxx # 控制横向滚动条位置
  • 4
    点赞
  • 31
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
### 回答1: Selenium 可以通过 JavaScript 代码控制网页内置滚动条,例如:driver.executeScript("window.scrollBy(x,y)"); 其 x 和 y 是滚动条滚动的像素数。 ### 回答2: 使用Selenium控制网页内置滚动条,需要使用WebDriver的一些方法和属性。 首先,我们需要定位到具有滚动条的元素,可以是整个网页或特定的窗口或框架。可以使用`driver.switch_to.frame()`方法来切换到窗口或框架,然后使用其他定位元素的方法来定位具有滚动条的元素。 一旦定位到元素,我们可以使用`execute_script()`方法来执行JavaScript代码,以模拟滚动条的操作。例如,我们可以使用JavaScript的`scrollIntoView()`方法将元素滚动到可见区域,或使用`scrollBy()`方法按照指定的像素数垂直或水平滚动。 以下是一个示例代码: ```python from selenium import webdriver driver = webdriver.Chrome() # 假设使用Chrome浏览器 driver.get("http://example.com") # 打开一个网页 # 定位到具有滚动条的元素 element = driver.find_element_by_css_selector("body") # 将元素滚动到可见区域 driver.execute_script("arguments[0].scrollIntoView();", element) # 垂直滚动到指定的像素数 driver.execute_script("window.scrollBy(0, 200);") # 水平滚动到指定的像素数 driver.execute_script("window.scrollBy(200, 0);") ``` 上述代码的执行过程如下: 1. 打开Chrome浏览器,并打开一个网页。 2. 定位到具有滚动条的元素(此处为整个网页的`body`元素)。 3. 执行JavaScript代码将元素滚动到可见区域。 4. 执行JavaScript代码垂直滚动页面200个像素。 5. 执行JavaScript代码水平滚动页面200个像素。 通过以上步骤,我们可以使用Selenium控制网页内置滚动条的操作。注意,使用`execute_script()`方法可以执行任意的JavaScript代码,因此还可以根据具体需要进行其他滚动操作。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值