我的调查页面的第一页有"选择年龄";以及";选择性别";。在我选择这些选项之后;继续";按钮,然后进入下一页。每一页都有一个问题。
HTML代码是:
<div id="survey-container"><div id="navigation-survey" style="display: none;"><strong>Pas NaN<span> / 11</span></strong><ul><li style="display: none;"><a class="isDisabled">1</a></li><li style="display: none;"><a class="isDisabled">2</a></li><li><a class="isDisabled">3</a></li><li><a class="isDisabled">4</a></li><li><a class="isDisabled">5</a></li><li><a class="isDisabled">6</a></li><li><a class="isDisabled">7</a></li><li><a class="isDisabled">8</a></li><li><a class="isDisabled">9</a></li><li><a class="isDisabled">10</a></li><li><a class="isDisabled">11</a></li><li><a class="isDisabled">12</a></li><li><a class="isDisabled">14</a></li></ul></div> <div class="start-survey-container"><div class="questions columns-2"><div><strong class="title">NaN. Selecteaza varsta</strong> <p class="description" style="display: none;"></p> <div class="question"><strong class="title">Selecteaza varsta</strong> <div class="answers"><label><img class="icon" style="display: none;"> <input type="radio" name="select-1" value="0"> 18-30 </label></div><div class="answers"><label><img class="icon" style="display: none;"> <input type="radio" name="select-1" value="1"> 31-50 </label></div><div class="answers"><label><img class="icon" style="display: none;">
<input type="radio" name="select-1" value="2"> 51-70 </label></div><div class="answers"><label><img class="icon" style="display: none;"> <input type="radio" name="select-1" value="3"> 71- </label></div> </div> <div class="disclaimer" style="display: none;"><label><input type="checkbox" id="disclaimer"> Text</p></div> <div classname="clearfix"></div> <div class="actions"><a id="prev" class="btn gray" style="display: none;"> Inapoi </a> <a id="next" class="btn isDisabled" style="display: none;"> Continua </a></div></div>
<div><strong class="title">NaN. Selecteaza sex</strong> <p class="description" style="display: none;"></p> <div class="question"><strong class="title">Selecteaza sex</strong> <div class="answers"><label><img class="icon" style="display: none;"> <input type="radio" name="select-2" value="0"> Masculin </label></div><div class="answers"><label><img class="icon" style="display: none;"> <input type="radio" name="select-2" value="1"> Feminin </label></div> </div>
问题是,您创建的任何定位器都无法访问所需的项目。也许每个问题之后都需要等待一段时间?
我的定位器:
@FindBy(css = "#survey-container input[type='radio'], input[value='0']")
WebElement years;
@FindBy(css = "#survey-container > div.start-survey-container > div.questions.columns-2 > div:nth-child(2) > div.question > div:nth-child(3) > label > input[type=radio]")
WebElement sex;
@FindBy(css = "#survey-container > div.start-survey-container > div.questions.columns-2 > div:nth-child(1) > div.question > div:nth-child(2) > label")
WebElement startSurvey;
有没有一种更容易的方法来识别想要的物品?你可以向我推荐一些与调查页面自动化相关的教程吗?
如果问题不是很清楚,我很感激你能告诉我如何根据StackOverflow规则写出好的问题。这里有新镜头。谢谢
问题如下:调查
你能用下面的代码检查一下吗,我希望这会对有所帮助
WebElement element = driver.findElement(By.xpath("((//input[@name='select-
1'])[1])"));
WebElement element2 = driver.findElement(By.xpath(((//input[@name='select-
2'])[1])"));
WebElement element3 = driver.findElement(By.xpath("//*[@id='start-
survey']"));
JavascriptExecutor executor = (JavascriptExecutor) driver;
executor.executeScript("arguments[0].click();", element);
executor.executeScript("arguments[0].click();", element2);
executor.executeScript("arguments[0].click();", element3);
我已经使用了JavascriptExecutor接口来与元素交互,如前所述,至少这是有效的,您可以根据自己的需求对其进行增强。
- 未遵循@FindBy
流程应该如下所示:
-
选择年龄-它可以是
drop down
或input field
。 -
选择性别-大多数情况下是
radio
button
。
您的定位器:
@FindBy(css = "#survey-container > div.start-survey-container > div.questions.columns-2 > div:nth-child(2) > div.question > div:nth-child(3) > label > input[type=radio]")
WebElement sex;
我相信它可以用一种更可靠的方式写,这里有CSS参考
有没有一种更容易的方法来识别想要的物品?-按照上面的链接
你可以向我推荐一些与调查页面自动化相关的教程吗?-我不认为只有在调查页面上,教程链接才有多大帮助。尽管我建议你看看XPATH参考
Selenium Java官方文档
作为一个初学者,你可能想看看这里
总是使用ExplicitWait类似这样的东西:
new WebDriverWait(driver, Duration.ofSeconds(3)).until(ExpectedConditions.elementToBeClickable(By.xpath("//a/h3")));
看看这是否有效:-
driver.findElement(By.xpath(".//label[text() =' 31-50 ']")).click();
driver.findElement(By.xpath(".//label[text() = ' Masculin ']")).click();
driver.findElement(By.xpath(".//button[text()='Continue']")).click();