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

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

其实,实现这个功能只要一行代码,但由于不懂js ,所以花了不小力气找到这种方法。

用于标识滚动条位置的代码

<body οnlοad= "document.body.scrollTop=0 ">

<body οnlοad= "document.body.scrollTop=100000 ">

如果滚动条在最上方的话,scrollTop=0 ,那么要想使用滚动条在最可下方,可以scrollTop=100000 ,这样就可以使滚动条在最下方。

场景一

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

js="var q=document.getElementById('id').scrollTop=10000" driver.execute_script(js)

注:由于法律条款的文字必须被阅读并接受才能进行下一步, 所以必须先将滚动条滑到底部,然后“接受”按钮才可用, 点击接受以后“下一步”按钮才可用。

场景二

有滚动条的页面到处可见,这个就比较容易找例子,我们以操作百度搜索结果页为例:

#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()

转自: http://tech.ddvip.com/2013-10/1383059700204981.html

以下是我自己的代码, C# + IE:

using Se = OpenQA.Selenium;
using SIE = OpenQA.Selenium.IE;//
SIE.InternetExplorerOptions _IEOptions = null;
SIE.InternetExplorerDriver _IEDriver = null;// init Internet driverprivate void InitIE(){_IEOptions = new SIE.InternetExplorerOptions();_IEOptions.IntroduceInstabilityByIgnoringProtectedModeSettings = true;_IEOptions.UnexpectedAlertBehavior = SIE.InternetExplorerUnexpectedAlertBehavior.Default;_IEOptions.ElementScrollBehavior = SIE.InternetExplorerElementScrollBehavior.Bottom;_IEDriver = new SIE.InternetExplorerDriver(_IEOptions);}private void Scroll Bar()
{IList<Se.IWebElement> frames = _IEDriver.FindElements(Se.By.TagName("frame"));Se.IWebElement frameDisplay = null;Se.IWebElement frameControlPanel = null;foreach (var frame in frames){if (frame.GetAttribute("name") == "ElementDisplayFrame"){frameDisplay = frame;}else if (frame.GetAttribute("name") == "ControlPanelFrame"){frameControlPanel = frame;}}if (frameDisplay != null){_IEDriver.SwitchTo().Frame(frameDisplay);// scroll to bottomSe.IWebElement ndaContainer = _IEDriver.FindElement(Se.By.Id("ndacontainer"));string id = ndaContainer.GetAttribute("id");var js = "var q = document.getElementById('" + id + "').scrollTop=10000";_IEDriver.ExecuteScript(js, null);ElementHP.Wait(_IEDriver);Se.IWebElement yesButton = _IEDriver.FindElement(Se.By.XPath("//input[@name='I1']"));if (yesButton != null && yesButton.Enabled){yesButton.Click();}}
}

转载于:https://www.cnblogs.com/qixue/p/3927325.html

Selenium - IWebDriver 控制scroll bar到底部相关推荐

  1. Div Scroll Bar (用层模拟滚动条)

    对Div的盒模型以及Css控制定位都不熟,所以遇到了不少BT问题--好在最终突破了种种困难,基本实现了自己想要的效果. 说明: 最大的突破是通过了 xhtml1-transitional.dtd 验证 ...

  2. NGUI 3.5教程(八)Scroll Bar 滚动条-制作聊天框

    NGUI 3.5教程(八)Scroll Bar 滚动条-制作聊天框 分类: Unity NGUI2014-08-05 18:19 2046人阅读 评论(8) 收藏 举报 NGUI 3.5教程NGUI聊 ...

  3. html select滚动轴,javascript - html select scroll bar - Stack Overflow

    how do you add a scroll bar to the html select box? is there any javascript library that emulate thi ...

  4. JavaFX UI控件教程(十)之Scroll Bar

    翻译自   Scroll Bar 本章介绍如何使用滚动条控件创建可滚动窗格. 本ScrollBar类可以在应用程序中创建滚动窗格和意见.图9-1显示了滚动条的三个区域:拇指,右侧和左侧按钮(或向下和向 ...

  5. 【Selenium】控制当前已经打开的 chrome浏览器窗口

    前言 有过几个小伙伴问过我如何利用 Selenium 获取已经打开的浏览器窗口,这里给安排了,还安排了两篇. 标题 链接 [Selenium]控制当前已经打开的 chrome浏览器窗口 https:/ ...

  6. 【Selenium】控制当前已经打开的 chrome浏览器窗口(高级版)

    前言 利用 Selenium 获取已经打开的浏览器窗口,全python操作 标题 链接 [Selenium]控制当前已经打开的 chrome浏览器窗口 https://blog.csdn.net/we ...

  7. Python用 selenium 模块控制Firefox浏览器

    Python用 selenium 模块控制Firefox浏览器 需要的东西: Firefox浏览器下载地址: http://getfirefox.com/ selenium包: https://pyp ...

  8. vue-cli网页聊天室:当聊天室有新消息时,控制滚动条滚动到底部

    做一个网页聊天室页面,功能需求是:当有新消息出现在聊天室页面时,控制页面滚动条滚动到页面底部: 聊天室页面代码如下: data中的消息列表: messageList: [{Character: &qu ...

  9. 使用selenium模块控制谷歌浏览器报错

    使用selenium模块控制谷歌浏览器报错: browser=selenium.webdriver.Chrome() Traceback (most recent call last):File &q ...

最新文章

  1. 斯坦福大学报告称中国AI论文引用率首超美国!但李国杰院士也发文灵魂拷问!...
  2. 一文告诉你,为什么要研究JVM原理
  3. GitHub 标星 7000+,面试官的灵魂 50 问,问到你怀疑人生!
  4. Python内置类型—序列
  5. Scala学习(十二)高阶函数
  6. 球体表面积原来还可以这么求!
  7. ssl提高组周六备考赛【2018.10.20】
  8. 机器学习基础—Kaggle泰坦尼克预测(完整分析)
  9. ARMA模型的性质之MA模型
  10. js字符串转日期类型
  11. 找图点击-找图自动点击全能模拟王软件
  12. Xamarin教程索引页
  13. 用C语言显示所有Ascll表
  14. tomcat日志详解
  15. django3 websockets
  16. tar:time stamp in the future
  17. ios重签工具避免双重认证
  18. 《计算传播学导论》读书笔记:第六章 网络传播模型与机器学习框架
  19. linux-2.6.32在mini2440开发板上移植(15)之移植看门狗驱动
  20. 大学计算机与人工智能基础课后答案,好书推荐 | 人工智能基础及应用

热门文章

  1. /deep/使用方式方式;/deep/无效; ::v-deep和>>>使用;
  2. Taro+react开发(88):大写px 控制样式
  3. 前端学习(3282):立即执行函数
  4. 前端学习(2912):MvvM的实现原理
  5. [css] 如何更改placeholder的字体颜色和大小?
  6. 工作290:重置新增的mode
  7. 前端学习(2561):页面更新
  8. 工作51:后端vue学习地址
  9. “约见”面试官系列之常见面试题第十篇值meta标签(建议收藏)
  10. 前端学习(1296):第三方模块nodemon