Selenium - IWebDriver 控制scroll bar到底部
有时候我们需要控制页面滚动条上的滚动条,但滚动条并非页面上的元素,这个时候就需要借助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到底部相关推荐
- Div Scroll Bar (用层模拟滚动条)
对Div的盒模型以及Css控制定位都不熟,所以遇到了不少BT问题--好在最终突破了种种困难,基本实现了自己想要的效果. 说明: 最大的突破是通过了 xhtml1-transitional.dtd 验证 ...
- NGUI 3.5教程(八)Scroll Bar 滚动条-制作聊天框
NGUI 3.5教程(八)Scroll Bar 滚动条-制作聊天框 分类: Unity NGUI2014-08-05 18:19 2046人阅读 评论(8) 收藏 举报 NGUI 3.5教程NGUI聊 ...
- 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 ...
- JavaFX UI控件教程(十)之Scroll Bar
翻译自 Scroll Bar 本章介绍如何使用滚动条控件创建可滚动窗格. 本ScrollBar类可以在应用程序中创建滚动窗格和意见.图9-1显示了滚动条的三个区域:拇指,右侧和左侧按钮(或向下和向 ...
- 【Selenium】控制当前已经打开的 chrome浏览器窗口
前言 有过几个小伙伴问过我如何利用 Selenium 获取已经打开的浏览器窗口,这里给安排了,还安排了两篇. 标题 链接 [Selenium]控制当前已经打开的 chrome浏览器窗口 https:/ ...
- 【Selenium】控制当前已经打开的 chrome浏览器窗口(高级版)
前言 利用 Selenium 获取已经打开的浏览器窗口,全python操作 标题 链接 [Selenium]控制当前已经打开的 chrome浏览器窗口 https://blog.csdn.net/we ...
- Python用 selenium 模块控制Firefox浏览器
Python用 selenium 模块控制Firefox浏览器 需要的东西: Firefox浏览器下载地址: http://getfirefox.com/ selenium包: https://pyp ...
- vue-cli网页聊天室:当聊天室有新消息时,控制滚动条滚动到底部
做一个网页聊天室页面,功能需求是:当有新消息出现在聊天室页面时,控制页面滚动条滚动到页面底部: 聊天室页面代码如下: data中的消息列表: messageList: [{Character: &qu ...
- 使用selenium模块控制谷歌浏览器报错
使用selenium模块控制谷歌浏览器报错: browser=selenium.webdriver.Chrome() Traceback (most recent call last):File &q ...
最新文章
- 斯坦福大学报告称中国AI论文引用率首超美国!但李国杰院士也发文灵魂拷问!...
- 一文告诉你,为什么要研究JVM原理
- GitHub 标星 7000+,面试官的灵魂 50 问,问到你怀疑人生!
- Python内置类型—序列
- Scala学习(十二)高阶函数
- 球体表面积原来还可以这么求!
- ssl提高组周六备考赛【2018.10.20】
- 机器学习基础—Kaggle泰坦尼克预测(完整分析)
- ARMA模型的性质之MA模型
- js字符串转日期类型
- 找图点击-找图自动点击全能模拟王软件
- Xamarin教程索引页
- 用C语言显示所有Ascll表
- tomcat日志详解
- django3 websockets
- tar:time stamp in the future
- ios重签工具避免双重认证
- 《计算传播学导论》读书笔记:第六章 网络传播模型与机器学习框架
- linux-2.6.32在mini2440开发板上移植(15)之移植看门狗驱动
- 大学计算机与人工智能基础课后答案,好书推荐 | 人工智能基础及应用
热门文章
- /deep/使用方式方式;/deep/无效; ::v-deep和>>>使用;
- Taro+react开发(88):大写px 控制样式
- 前端学习(3282):立即执行函数
- 前端学习(2912):MvvM的实现原理
- [css] 如何更改placeholder的字体颜色和大小?
- 工作290:重置新增的mode
- 前端学习(2561):页面更新
- 工作51:后端vue学习地址
- “约见”面试官系列之常见面试题第十篇值meta标签(建议收藏)
- 前端学习(1296):第三方模块nodemon