zoukankan      html  css  js  c++  java
  • Selenium学习笔记之013:控制滚动条到底部 分类: Selenium 2015-07-23 00:26 19人阅读 评论(0) 收藏

    •   控制滚动条到底部

     

    有时候我们需要控制页面滚动条上的滚动条,但滚动条并非页面上的元素,这个时候就需要借助js是来进行操作。一般用到操作滚动条的会两个场景:

    • 注册时的法律条文需要阅读,判断用户是否阅读的标准是:滚动条是否拉到最下方。
    • 要操作的页面元素不在吸视范围,无法进行操作,需要拖动滚动条

    这里需要掌握一些JS的知识,其方法如下:
    用于标识滚动条位置的代码
    <span style="font-size:12px;"><body   onload= "document.body.scrollTop=0 ">
    <body   onload= "document.body.scrollTop=100000 "></span>
    如果滚动条在最上方的话,scrollTop=0 ,那么要想使用滚动条在最可下方,可以scrollTop=100000 ,这样就可以使滚动条在最下方。

    场景一

    先来解决场第一个问题,法律条款是一个内嵌窗口,通过firebug工具可以定位到内嵌入窗口可以定位到元素的id ,可以通过下面的代码实现。

    <span style="font-size:12px;">js="var q=document.getElementById('id').scrollTop=10000"
    driver.execute_script(js)</span>


    场景二
    有滚动条的页面到处可见,这个就比较容易找例子,我们以操作百度搜索结果页为例:
    #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()

    文章参考资料:

    版权声明:本文为博主原创文章,未经博主允许不得转载。

  • 相关阅读:
    MarkDown学习
    做网站的或者博客的网站
    Calendar日历简单用法
    Cron表达式范例
    CSVFileUtil 读取写入CSV文件简单工具类
    直接读取ZIP包数据 线上、线下方法
    Spring @Async/@Transactional 失效的原因及解决方案
    多线程学习 读写锁
    多线程学习 公平锁和非公平锁
    多线程学习 ThreadLocal的使用。
  • 原文地址:https://www.cnblogs.com/haixianglan/p/4678038.html
Copyright © 2011-2022 走看看