javascript – 访问shadow-root中的元素

是否可以使用java和selenium找到Shadow DOM的元素?

我想从影子根获取元素

<paper-input id="homeSearch" class="home-search-btn home-inputs" placeholder="Where would you like to go?" no-label-float="" tabindex="0" aria-disabled="false"><iron-icon icon="-search-" slot="prefix" class="form-icons search-icon"></iron-icon></paper-input>

我想在homesearch上发送一个输入,例如driver.findElement(By.id(“homesearch”));我在互联网上搜索但没有获得任何合适的解决方案.

enter image description here

任何类型的帮助将非常感激

解决方法:

在阴影根目录中获取元素需要几个步骤.

首先,获取’host’元素,在您的情况下输入属性page =“home”

WebElement host1 = driver.findElement(By.cssSelector("vrs-app[page='home']"));

之后,您需要执行JavaScript脚本以从主机获取影子根,您可以通过在Web元素上调用.shadowRoot来获取影子根.

WebElement shadowRoot = (WebElement)((JavascriptExecutor) driver).executeScript("return arguments[0].shadowRoot", host);

但有一个问题,你的输入嵌套在几个阴影dom中,所以你必须这样做几次.最有效的方法是使用一种方法,例如:

public WebElement GetShadowRoot(WebElement host) {
    WebElement shadowRoot = (WebElement)((JavascriptExecutor) driver).executeScript("return arguments[0].shadowRoot", host);
    return shadowRoot ;
}

之后,潜入所有阴影根,直到你到达你需要的主机,如下所示:

WebElement host1 = driver.FindElement(By.cssSelector("vrs-app[page='home']"));
WebElement shadow1 = GetShadowRoot(host1);

WebElement host2 = shadow1.FindElement(By.cssSelector("vrs-home"));
WebElement shadow2 = GetShadowRoot(host2);

// We've reached the shadow dom containing the input
// Note: I'm not using By.id since this may throw an error
WebElement paperInput = shadow2.findElement(By.cssSelector("paper-input[id='homeSearch']"));

现在,您可以使用paperInput执行您想要执行的操作.

旁注:我知道这种方法适用于Chrome(刚刚测试过),还没有在其他浏览器中测试过.另外,我不懂Java,所以语言语法可能有点不同.

相关文章

转载地址:https://www.cnblogs.com/mini-monkey/p/12104821...
web自动化测试过程中页面截图相对比较简单,可以直接使用sel...
目录前言一、Selenium简介二、浏览器驱动1.浏览器驱动参考2....
一、iframe的含义:iframe是HTML中框架的一种形式,在对界面...
转载请注明出处❤️作者:测试蔡坨坨原文链接:caituotuo.to...
'''##**认识selenium**​**下载:pipinstall...