以下は私のhtmlコードです:私が最初に見つけたいセレンの特定のウェブ要素内の即時ウェブ要素を見つける方法を教えてください。
<div class="abc">
<ul class="a">
<li></li>
<ul class="b">
<ul class="c">
<div class="abcd">
<ul class="d">
<li></li>
UL要素
css locator would be = div.abc > ul
しかし、私は、コードの下に使用して、この要素を探したい:
final String firstUlElement = ">ul";
@FindBy(css = ".div.abc")
WebElement divElement;
List<WebElement> firstUlElement = this.divElement.findElements(By.cssSelector(firstUlElement));
しかし、次のエラーをスローする:
The given selector >ul> is either invalid or does not result in a WebElement. The following error occurred:
InvalidSelectorError: An invalid or illegal selector was specified
Command duration or timeout: 7 milliseconds
For documentation on this error, please visit: http://seleniumhq.org/exceptions/invalid_selector_exception.html
Build info: version: '2.53.0', revision: '35ae25b', time: '2016-03-15 16:57:40'
System info: host: 'PratikPat-w7', ip: '192.168.56.1', os.name: 'Windows 7', os.arch: 'amd64', os.version: '6.1', java.version: '1.7.0_71'
*** Element info: {Using=css selector, value=>ul}
Session ID: ba99cd84-0640-4af7-870a-50d79d893332
Driver info: org.openqa.selenium.firefox.FirefoxDriver
したがって、上記のコードを使用してdiv.abcの後に最初の即時要素を見つける方法はありますか? Thnaksは事前
私は '>'を使用しないとすべてのul要素を取りますが、私は 'div.abc'の直下の子を必要とします –
この方法では、 'div.abcの子である' ul' '。私が 'findElements()'を使ってノートで述べたように、これらの要素すべてを含むリストを返します。あなたは最初のものだけを 'findElement()'に変更する必要があります。 – RemcoW
DOM内に 'div.abc> ul'要素がたくさんあるので、うまくいくでしょうが、' div.abc> ul'要素の階層が必要です利用可能な、私はすべてのタイプのロケータのリストが必要です..ありがとう。 –