Selenium滚动条处理

Selenium是一个用于Web应用程序自动化测试工具,可以直接运行在浏览器中,针对页元素来进行定位并模仿认为操作。但是却无法控制滚动条,这时候只能借助JS了,selenium提供了一个操作js的方法:execute_script(),可以直接执行js的脚本。

一,控制滚动条纵向移动:

def  LongitudinalRolling(num):
    #num用来修改scrollTop,可以控制右侧滚动条滚动位置,0为滚动到顶部,10000为最底部
    js = "var q=document.getElementById('id').scrollTop="+num
    driver.execute_script(js)

二,控制滚动条横向移动:

#将x,y插入js字符串
def Change_JS(x, y):
    js = "window.scrollTo(,);"
    str_js1 = list(js)
    scrollTo_x = str_js1.index(',')
    str_js1.insert(scrollTo_x, str(x))
    js1 = ''.join(str_js1)
    str_js2 = list(js1)
    scrollTo_y = str_js2.index(')')
    str_js2.insert(scrollTo_y, str(y))
    js2 = ''.join(str_js2)
    return js2

#通过坐标(x, y)控制横向和纵向滚动条
def TransverseRolling(x,y):
    js = Change_JS(x, y)
    driver.execute_script(js)

三,控制div内嵌滚动条滚动

#内嵌滚动条滚动
def DivRolling(self,classname,method='div',direction='left', num=0,num2=0):
    '''
    :param classname: 内嵌div的classname
    :param method: 内嵌windows/div
    :param direction: 滚动条滚动方向
    :param num: 左边距
    :param num2: 上边距
    '''
    try:
        if method == 'div':
            if direction == 'top':
                js = 'document.getElementsByClassName("{}")[0].scrollTop=' \
                     '{}'.format(classname, num)
                self.driver.execute_script(js)
            elif direction == 'left':
                js = 'document.getElementsByClassName("{}")[0].scrollLeft=' \
                         '{}'.format(classname, num)
                    self.driver.execute_script(js)
                else:
                    pass
        if method == 'window':
            js = "window.scrollTo({},{})".format(num, num2)
            return self.driver.execute_script(js)
    except Exception as e:
        raise e

  • 1
    点赞
  • 27
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 1
    评论
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

帅冒

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值