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

项目过程当中遇到操作滚动条问题:

这里是浏览器内嵌的横向滚动条,页面有2个TAB,

 

这里主要是操作TAB2里面的横向滚动条,下图可以看出class= el-table__body-wrapper is-scrolling-left

2个tab 那么操作第2个tab ,横向滚动到右侧,代码如下

 js = 'document.getElementsByClassName("el-table__body-wrapper is-scrolling-left")[1].scrollLeft=10000'
 self.driver.execute_script(js)

实际要根据你页面情况变动,如果你要操作时,滚动条位置发生了变化,假设tab2的 横向滚动条右移动了,这时候

class =el-table__body-wrapper is-scrolling-middle

那么操作这个tab2的滚动条就是

js = 'document.getElementsByClassName("el-table__body-wrapper is-scrolling-middle")[0].scrollLeft=10000'
 self.driver.execute_script(js)

# 这里有2个变化,下标变成0了,因为第一个页面还是left,所有这里是0
# 第二个是使用新的class名称

 

 

很多人疑惑怎么用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 # 控制横向滚动条位置

评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值