这是我的java代码。
@TimeIt(key = "click")
private void clickEvent(String uiIdentifierVariableName, boolean retry) throws Exception {
findElement(uiIdentifierVariableName);
WebElement webElement = ensureElementClickable(uiIdentifierVariableName);
webElement.click(
}
这是我的html内容
<div _ngcontent-akc-c53="" class="nav ng-star-inserted is-mobile" bis_skin_checked="1" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="mobile-side-nav ng-star-inserted" bis_skin_checked="1">
<div _ngcontent-akc-c53="" class="side-container-bg ng-star-inserted" bis_skin_checked="1" style="display: block;"></div>
<div _ngcontent-akc-c53="" id="mySidenav" class="side-container ng-star-inserted" bis_skin_checked="1" style="width: 185px;">
<div _ngcontent-akc-c53="" class="responsive-side-background ng-star-inserted" bis_skin_checked="1"></div>
<!---->
<a _ngcontent-akc-c53="" class="menu-item ng-star-inserted" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="icon search_icon" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text"> Search </span><!---->
</a>
<!----><!---->
<a _ngcontent-akc-c53="" class="menu-item active ng-star-inserted" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="icon home_icon active" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text"> Home </span>
<div _ngcontent-akc-c53="" class="nav__selected-item-triangle ng-star-inserted" bis_skin_checked="1" style="background-position: left 0% center;"></div>
<!---->
</a>
<!----><!---->
<a _ngcontent-akc-c53="" class="menu-item ng-star-inserted" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="icon movie_icon" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text"> Movies </span><!---->
</a>
<!----><!---->
<a _ngcontent-akc-c53="" class="menu-item ng-star-inserted" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="icon live_icon" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text"> Live Channels </span><!---->
</a>
<!----><!---->
<a _ngcontent-akc-c53="" class="menu-item ng-star-inserted" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="icon stories_icon" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text"> Stories </span><!---->
</a>
<!----><!---->
<a _ngcontent-akc-c53="" class="menu-item ng-star-inserted" style="border-color: rgb(194, 204, 216);">
<div _ngcontent-akc-c53="" class="icon kids_icon" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text"> Kids </span><!---->
</a>
<!----><!----><!----><!---->
</div>
<div _ngcontent-akc-c53="" class="mobile-toggle ng-star-inserted" bis_skin_checked="1">
<div _ngcontent-akc-c53="" id="hamburger" class="hamburger-icon change" bis_skin_checked="1">
<div _ngcontent-akc-c53="" class="bar1 mobile" bis_skin_checked="1"></div>
<div _ngcontent-akc-c53="" class="bar2 mobile" bis_skin_checked="1"></div>
<div _ngcontent-akc-c53="" class="bar3 mobile" bis_skin_checked="1"></div>
</div>
<div _ngcontent-akc-c53="" class="home_icon hover icon" bis_skin_checked="1" style="opacity: 1;"></div>
</div>
<!---->
</div>
<!----><!---->
<div _ngcontent-akc-c53="" class="right-container" bis_skin_checked="1">
<!---->
<a _ngcontent-akc-c53="" class="menu-item menu-item__profile ng-star-inserted">
<div _ngcontent-akc-c53="" class="icon profile_icon" bis_skin_checked="1"></div>
<span _ngcontent-akc-c53="" class="text menu-item__profile-text">Profiles</span>
</a>
<!---->
</div>
</div>
当我在 //span[contains(text(),'Search')] 中传递此 xPath 时,现在单击导航栏即可打开
我的测试用例正在通过,并且 appium 日志我也可以看到这是可点击的。但实际上我无法导航到搜索按钮。可能出现什么问题。 甚至无法在整个导航弹出窗口中进行搜索,只是我无法单击。当我使用浏览器堆栈时。 此问题发生在 ios webview safari 浏览器中。同样的事情在 android chrome 中工作得很好。
@TimeIt(key = "click")
private void clickEvent(String uiIdentifierVariableName, boolean retry) 抛出异常 {
findElement(uiIdentifierVariableName);
WebElement webElement = ensureElementClickable(uiIdentifierVariableName);
webElement.click();
}
可能您在 webelement.click(); 中缺少右括号