如何在selenium中使用js实现定位


Posted in Javascript onAugust 18, 2020

学习selenium的时候经常用扫的定位方式WebDriver定位方式,但是一些Windows的窗口就无力了,这时候可以用js定位

使用js定位的时候是用DOM树定位方式

eg:

document.getElementById("su");

这里就可以看出来,和浏览器中的console控制台的定位方式一样样的——果然知识都是相通的

如何在selenium中使用js实现定位

接下来就是正题:

selenium中执行js脚本:

第一步首先强转成JavascriptExcetor:

JavaScriptExecutor js = (JavascriptExecutor) driver;

然后用此JavascriptExcetor对象调用js定位的方法

举例:

// 设置日期控件的读写属性
((JavascriptExecutor) driver).executeScript("document.getElementById(\"fromDate\").readOnly=false");
// 直接为日期控件强行赋值
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("document.getElementById('fromDate').setAttribute('value','2013-06-21');");
// 富文本编辑框的处理
driver.switchTo().frame("ueditor_0");
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("document.body.innerHTML='ABCDEFG'");
//js模拟点击
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("arguments[0].click();",driver.findElement(By.id("su")));
//滚动条操作
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("document.documentElement.scrollTop=1500");
//元素赋值
document.getElementById('HD_CheckIn').value='zhangsan';
//日期类型元素赋值
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("arguments[0] .value=‘2016-04-20';",driver.findElement(By*****)));

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
jquery实现个人中心导航菜单效果和美观都非常不错
Sep 02 Javascript
借助FileReader实现将文件编码为Base64后通过AJAX上传
Dec 24 Javascript
js实现图片无缝滚动特效
Mar 19 Javascript
url传递的参数值中包含&时,url自动截断问题的解决方法
Aug 02 Javascript
javascript实现无法关闭的弹框
Nov 27 Javascript
利用select实现年月日三级联动的日期选择效果【推荐】
Dec 13 Javascript
jQuery监听浏览器窗口大小的变化实例
Feb 07 Javascript
JavaScript中清空数组的三种方式
Mar 22 Javascript
详解如何构建Angular项目目录结构
Jul 13 Javascript
vue实现点击隐藏与显示实例分享
Feb 13 Javascript
Angular7中创建组件/自定义指令/管道的方法实例详解
Apr 02 Javascript
vue中 this.$set的使用详解
Nov 17 Vue.js
vue实现移动端input上传视频、音频
Aug 18 #Javascript
React冒泡和阻止冒泡的应用详解
Aug 18 #Javascript
JavaScript数组排序的六种常见算法总结
Aug 18 #Javascript
js实现简单扫雷
Nov 27 #Javascript
基于JavaScript实现大文件上传后端代码实例
Aug 18 #Javascript
javascript实现扫雷简易版
Aug 18 #Javascript
详解Vue的组件中data选项为什么必须是函数
Aug 17 #Javascript
You might like
彻底删除thinkphp3.1案例blog标签的方法
2014/12/05 PHP
php+ajax 文件上传代码实例
2019/03/18 PHP
Laravel 实现Controller向blade前台模板赋值的四种方式小结
2019/10/22 PHP
jqGrid增加时--判断开始日期与结束日期(实例解析)
2013/11/08 Javascript
jquery处理json数据实例分析
2014/06/03 Javascript
Javascript的&&和||的另类用法
2014/07/23 Javascript
Javascript中arguments和arguments.callee的区别浅析
2015/04/24 Javascript
jQuery移动页面开发中的触摸事件与虚拟鼠标事件简介
2015/12/03 Javascript
jquery插件jquery.confirm弹出确认消息
2015/12/22 Javascript
jQuery 限制输入字符串长度
2016/06/20 Javascript
Vue.js每天必学之过滤器与自定义过滤器
2016/09/07 Javascript
详解js的事件处理函数和动态创建html标记方法
2016/12/16 Javascript
解决angularJS中input标签的ng-change事件无效问题
2018/09/13 Javascript
使用pm2部署node生产环境的方法步骤
2019/03/09 Javascript
Layui Form 自定义验证的实例代码
2019/09/14 Javascript
vue使用Sass时报错问题的解决方法
2020/10/14 Javascript
[01:23]一分钟告诉你 DOTA2为什么叫信仰2
2014/06/20 DOTA
[52:05]EG vs OG 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/18 DOTA
在Python3中初学者应会的一些基本的提升效率的小技巧
2015/03/31 Python
Python实现批量下载图片的方法
2015/07/08 Python
python调用OpenCV实现人脸识别功能
2018/05/25 Python
python数据处理 根据颜色对图片进行分类的方法
2018/12/08 Python
浅析Python3中的对象垃圾收集机制
2019/06/06 Python
Windows 安装 Anaconda3+PyCharm的方法步骤
2019/06/13 Python
Django 创建/删除用户的示例代码
2019/07/24 Python
python tkinter基本属性详解
2019/09/16 Python
关于Python3 lambda函数的深入浅出
2019/11/27 Python
Python基于类路径字符串获取静态属性
2020/03/12 Python
CSS3教程:background-clip和background-origin
2008/10/17 HTML / CSS
一款纯css3制作的2015年元旦雪人动画特效教程
2014/12/29 HTML / CSS
党员自我评价分享
2013/12/13 职场文书
2014学雷锋活动心得体会
2014/03/10 职场文书
土建施工员岗位职责
2015/04/11 职场文书
2015新员工工作总结范文
2015/10/15 职场文书
浅谈Python协程asyncio
2021/06/20 Python
5人制售《绝地求生》游戏外挂获利500多万元 被判刑
2022/03/31 其他游戏