selenium常用的js总结
1、 对input执行输入
直接设置value属性, 此方法主要应对输入框自动补全以及readonly属性的element,sendkeys不稳定
比如:
//inputbox is a WebElement JavascriptExecutor js = (JavascriptExecutor) driver; js.executeScript("arguments[0].value=\"北京\"", from_inpox);
对此可以封装一个typeQuick的方法
/** * @author Young * @param locator * @param values * @throws Exception */ protected void typeQuick(Locator locator, String values) throws Exception { WebElement e = findElement(driver, locator); log.info("type value is: " + values); JavascriptExecutor js = (JavascriptExecutor) driver; js.executeScript("arguments[0].value=\""+values+"\"", e);
去掉只读属性
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("arguments[0].removeAttribute(\"+"readonly"+\")", e);
2.对富文本框的操作
主要应对富文本框,可以封装获取富文本框内容和设置富文本路况内容的方法
JavascriptExecutor js = (JavascriptExecutor) driver; WebElement editor = driver.findElement(By.tagName("body")); js.executeScript( "arguments[0].innerHTML = '<h1>Selenium Test </h1>I love Selenium <br> this article Post By Selenium WebDriver<br><h2>Create By Young</h2>'", editor);
设置富文本框内容
/** * @author Young * @param locator * @param text */ protected void setRichTextBox(Locator locator, String text) { WebElement e = findElement(driver, locator); log.info("type value is: " + text); JavascriptExecutor js = (JavascriptExecutor) driver; js.executeScript("arguments[0].innerHTML = \"" + text + "\"", e); }
获取富文本框内容:
/** * @author Young * @param locator * @param text * @return */ protected String getRichTextBox(Locator locator, String text) { WebElement e = findElement(driver, locator); log.info("type value is: " + text); JavascriptExecutor js = (JavascriptExecutor) driver; String result=(String) js.executeScript("var result=arguments[0].innerHTML;return result", e); return result; }
3. 滚动到指定位置
为啥使用滚动? 因为如果页面没有完全显示,element如果是在下拉之后才能显示出来,只能先滚动到该元素才能进行click,否则是不能click操作
1 2 3 | JavascriptExecutor js=(JavascriptExecutor)driver; // roll down and keep the element to the center of browser js.executeScript( "arguments[0].scrollIntoViewIfNeeded(true);" , download); |
可以封装滚动到元素的方法的
/** * @author Young * @param locator */ protected void scrollToElement(Locator locator) { WebElement e = findElement(driver, locator); log.info("scroll view element"); JavascriptExecutor js = (JavascriptExecutor) driver; // roll down and keep the element to the center of browser js.executeScript("arguments[0].scrollIntoViewIfNeeded(true);", e); }
4. 触发event,Dom event 事件的封装
/** * For DOM Event * @author Young * @param locator * @param event * please refer to: http://www.w3school.com.cn/jsref/dom_obj_event.asp * */ public void DOMEvent(Locator locator,String event) { JavascriptExecutor jse=((JavascriptExecutor)driver); String js="var event;if (document.createEvent){event = document.createEvent(\"HTMLEvents\");event.initEvent(\""+event+"\", true, false);arguments[0].dispatchEvent(event);} else {arguments[0].fireEvent(\"on"+event+"\")}"; jse.executeScript(js, findElement(driver,locator)) ; }
五、获取元素属性
window.getComputedStyle(document.getElementById("su"),null).getPropertyValue("background")
六 、获取页面加载状态
document.readyState
转载请注明出处:http://www.cnblogs.com/tobecrazy/

【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
· 探究高空视频全景AR技术的实现原理
· 理解Rust引用及其生命周期标识(上)
· 浏览器原生「磁吸」效果!Anchor Positioning 锚点定位神器解析
· DeepSeek 开源周回顾「GitHub 热点速览」
· 物流快递公司核心技术能力-地址解析分单基础技术分享
· .NET 10首个预览版发布:重大改进与新特性概览!
· AI与.NET技术实操系列(二):开始使用ML.NET
· 单线程的Redis速度为什么快?