我只在 Chrome 中看到这个。
完整的错误消息如下:
“org.openqa.selenium.WebDriverException:元素在点 (411, 675) 不可点击。其他元素将收到点击:...”
“将收到点击”的元素位于相关元素的一侧,而不是在它的顶部,也没有重叠,也没有在页面上移动。
我尝试添加偏移量,但这也不起作用。该项目在显示的窗口上,无需滚动。
我只在 Chrome 中看到这个。
完整的错误消息如下:
“org.openqa.selenium.WebDriverException:元素在点 (411, 675) 不可点击。其他元素将收到点击:...”
“将收到点击”的元素位于相关元素的一侧,而不是在它的顶部,也没有重叠,也没有在页面上移动。
我尝试添加偏移量,但这也不起作用。该项目在显示的窗口上,无需滚动。
这是由以下3种类型引起的:
1.该元素是不可见的点击。
使用Actions或JavascriptExecutor使其点击。
按操作:
WebElement element = driver.findElement(By("element_path"));
Actions actions = new Actions(driver);
actions.moveToElement(element).click().perform();
通过 JavascriptExecutor:
JavascriptExecutor jse = (JavascriptExecutor)driver;
jse.executeScript("scroll(250, 0)"); // if the element is on top.
jse.executeScript("scroll(0, 250)"); // if the element is on bottom.
或者
JavascriptExecutor jse = (JavascriptExecutor)driver;
jse.executeScript("arguments[0].scrollIntoView()", Webelement);
然后点击元素。
2.页面在点击元素之前被刷新。
为此,让页面等待几秒钟。
3. 元素是可点击的,但上面有一个微调器/叠加层
下面的代码将等到覆盖消失
By loadingImage = By.id("loading image ID");
WebDriverWait wait = new WebDriverWait(driver, timeOutInSeconds);
wait.until(ExpectedConditions.invisibilityOfElementLocated(loadingImage));
然后点击元素。
您也可以使用 JavaScript 单击,然后不需要滚动。
IJavaScriptExecutor ex = (IJavaScriptExecutor)Driver;
ex.ExecuteScript("arguments[0].click();", elementToClick);
chromedriver 中似乎有一个错误(问题是它被标记为无法修复)-> GitHub Link
(也许在FreedomSponsors上悬赏?)
评论 #27 建议了一个解决方法。也许它会为你工作-
我有同样的问题,尝试了所有提供的解决方案,但它们对我不起作用。最终我使用了这个:
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeScript("var evt = document.createEvent('MouseEvents');" + "evt.initMouseEvent('click',true, true, window, 0, 0, 0, 0, 0, false, false, false, false, 0,null);" + "arguments[0].dispatchEvent(evt);", findElement(element));
希望这可以帮助
哇,这里有很多答案,还有很多好答案。
我希望我能从我的经验中添加一些东西。
伙计们,在我的情况下,偶尔会有一个 cookie 覆盖隐藏该元素。滚动到元素也可以;但以我的拙见(就我而言,不是每个人的灵丹妙药),最简单的解决方案就是全屏显示(我在屏幕窗口的 3/4 上运行我的脚本)!所以我们开始:
driver.manage().window().maximize();
希望有帮助!
您需要在该元素上使用焦点或滚动。您可能还必须使用显式等待。
WebElement firstbutton= driver.findElement(By.xpath("Your Element"));
Actions actions = new Actions(driver);
actions.moveToElement(element);
actions.perform();
或者
该元素不可点击,因为它上面有一个 Spinner/Overlay:
By loadingImage = By.id("loading image ID");
WebDriverWait wait = new WebDriverWait(driver, timeOutInSeconds);
wait.until(ExpectedConditions.invisibilityOfElementLocated(loadingImage));
或者
Point p= element.getLocation();
Actions actions = new Actions(driver);
actions.moveToElement(element).movebyoffset(p.x,p.y).click().perform();
或者
如果仍然无法使用JavascriptExecutor
JavascriptExecutor executor = (JavascriptExecutor)driver;
executor.executeScript("arguments[0].click();", firstbutton);
我在硒驱动的 Chrome 窗口打开太小的情况下看到了这一点。要单击的元素不在视口中,因此它失败了。
这听起来合乎逻辑......真正的用户必须调整窗口大小或滚动,以便可以看到元素并实际上单击它。
在指示 selenium 驱动程序适当地设置窗口大小后,这个问题对我来说就消失了。此处描述了webdriver API 。
使用 xvfb-run 无头运行测试时出现此错误。他们在本地完美地工作。使用 chrome,webdriver / chromedriver / chrome / java 等的版本都相同。
chromedriver 中的“无法修复”错误 - Tony Lâmpada 指出的GitHub 链接表明这可能与屏幕上可见/不可见有关。
xvfb-run 的帮助消息显示如下:
-s ARGS --server-args=ARGS arguments (other than server number and
"-nolisten tcp") to pass to the Xvfb server
(default: "-screen 0 640x480x8")
更改 xvfb 的分辨率使错误消失:
xvfb-run -s "-screen 0 1280x1024x16" ...
我也曾为这个问题而苦苦挣扎。代码在 FF 中运行良好,在 Chrome 上失败。我试图做的是单击一个复选框 - 如果它不在视图中,我会滚动查看然后单击。即使在 Chrome 中滚动到视图中,只有复选框的底部几个像素不可见,因此 webdriver 拒绝单击它。
我的解决方法是这样的:
WebElement element = _sectorPopup.findElement(...);
((Locatable) element).getCoordinates().inViewPort();
try {
element.click();
} catch (Exception e) {
new Actions(getWebDriver()).sendKeys(Keys.PAGE_DOWN).perform();
element.click();
}
Chrome 也有 sendKeys 的问题,有时需要使用 Actions。显然,您需要知道哪个方向以及您需要走多少,因此您的里程可能会有所不同。但我更喜欢这个而不是 javascript hack,所以我在这里发布它以防其他人会发现它有用。
红宝石/watir-webdriver/chrome
我使用以下技巧,似乎它有效:
#scroll to myelement
@browser.execute_script "window.scrollTo(#{myelement.element.wd.location[0]},#{myelement.element.wd.location[1]})"
# click myelement
myelement.when_present.fire_event("click")
首先,尝试获取最新的 Chrome 驱动程序并检查它是否可以解决问题。
就我而言,它没有解决问题。但是,到目前为止,以下解决方案对我有用。以下是 C# 代码,但您可以在特定语言中遵循相同的逻辑。我们在这里所做的是,
第 1 步:使用 Selenium Actions 对象关注元素,
第2步:然后单击元素
第 3 步:如果出现异常,则通过 Selenium 浏览器驱动程序的“ExecuteScript”方法执行 javascript 脚本,在元素上触发 javascript“Click”事件。
您也可以跳过第 1 步和第 2 步,也可以只尝试第 3 步。第 3 步可以自行运行,但我注意到在一种情况下出现了一些奇怪的行为,其中第 3 步即使成功单击了元素,也会在单击元素后导致代码的其他部分出现意外行为。
try
{
//Setup the driver and navigate to the web page...
var driver = new ChromeDriver("folder path to the Chrome driver");
driver.Navigate().GoToUrl("UrlToThePage");
//Find the element...
var element = driver.FindElement(By.Id("elementHtmlId"));
//Step 1
new Actions(driver).MoveToElement(element).Perform();
//Step 2
element.Click();
}
catch (Exception)
{
//Step 3
driver.ExecuteScript("document.getElementById('elementHtmlId').click();");
}
使用量角器时,这对我有帮助:
var elm = element(by.css('.your-css-class'));
browser.executeScript("arguments[0].scrollIntoView();", elm.getWebElement());
elm.click();
我根据 Tony Lâmpada 的回答中的评论制作了这种方法。它工作得很好。
def scroll_to(element)
page.execute_script("window.scrollTo(#{element.native.location.x}, #{element.native.location.y})")
end
我在 python 中运行 selenium 脚本时遇到了同样的问题。这是我用来单击元素的内容:
from selenium.webdriver.common.action_chains import ActionChains
ActionChains(driver).click(element).perform()
今天我遇到了同样的问题。如果我说我是如何解决问题的,你不相信我。
By maximizing the browser size
是的,这是一个指针问题,意味着浏览器的大小。为此,您只需要手动或通过代码最大化窗口大小。
我遇到了一个类似的问题,我必须一个接一个地检查两个复选框。但是我在上面的错误中得到了相同的结果。因此我在检查复选框的步骤之间添加了等待......它工作得很好。以下是步骤:-
When I visit /administrator/user_profiles
And I press xpath link "//*[@id='1']"
Then I should see "Please wait for a moment..."
When I wait for 5 seconds
And I press xpath link "//*[@id='2']"
Then I should see "Please wait for a moment..."
When I visit /administrator/user_profiles_updates
显然,这是 Chrome 驱动程序二进制文件中“无法修复”错误的结果。
一个对我有用的解决方案(我们的里程可能会有所不同)可以在这个 Google Group 讨论中找到,评论 #3:
https://groups.google.com/forum/?fromgroups=#!topic/selenium-developer-activity/DsZ5wFN52tc
相关部分就在这里:
从那以后,我通过直接导航到跨度的父锚点的 href 解决了这个问题。
driver.Navigate().GoToUrl(driver.FindElement(By.Id(embeddedSpanIdToClick)).FindElement(By.XPath("..")).GetAttribute("href"));
在我的例子中,我使用的是 Python,所以一旦我得到了想要的元素,我就简单地使用了
driver.get(ViewElm.get_attribute('href'))
但是,我希望这仅适用于您尝试单击的元素是链接...
Re Tony Lâmpada 的回答,评论 #27 确实为我解决了这个问题,除了它提供了 Java 代码并且我需要 Python。这是一个 Python 函数,它滚动到元素的位置,然后单击它。
def scroll_to_and_click(xpath):
element = TestUtil.driver.find_element_by_xpath(xpath)
TestUtil.driver.execute_script('window.scrollTo(0, ' + str(element.location['y']) + ');')
element.click()
这解决了我在 Chrome 34.0 中的问题。它对 Firefox 28.0 和 IE 11 没有任何危害;这些浏览器不会出现问题,但是在单击之前滚动到元素的位置仍然不是一件坏事。
错误信息的解释:
错误消息只是说,您要单击的元素存在,但它不可见。它可能被某些东西覆盖或暂时不可见。
元素在测试时不可见的原因可能有很多。请重新分析您的页面并为您的案例找到合适的解决方案。
特殊情况的解决方案:
就我而言,当我刚刚单击的屏幕元素的工具提示弹出我要单击的下一个元素时,就会发生此错误。散焦是我需要的解决方案。
element.blur()
弹出工具提示的元素,这会使工具提示消失。此错误的原因是您尝试单击的元素不在浏览器的视口(用户看到的区域)中。所以克服这个问题的方法是首先滚动到所需的元素,然后执行点击。
Javascript:
async scrollTo (webElement) {
await this.driver.executeScript('arguments[0].scrollIntoView(true)', webElement)
await this.driver.executeScript('window.scrollBy(0,-150)')
}
爪哇:
public void scrollTo (WebElement e) {
JavascriptExecutor js = (JavascriptExecutor) driver;
js.executeAsyncScript('arguments[0].scrollIntoView(true)', e)
js.executeAsyncScript('window.scrollBy(0,-150)')
}
如果在驱动程序尝试单击它时元素改变了位置,则可能会发生这种情况(我在 IE 中也看到过这种情况)。驱动程序保留初始位置,但当它实际点击它时,该位置不再指向该元素。顺便说一句,FireFox 驱动程序没有这个问题,显然它以编程方式“点击”元素。
无论如何,当您使用动画或简单地动态更改元素的高度(例如$("#foo").height(500)
)时,可能会发生这种情况。您需要确保仅在元素的高度“稳定”后单击元素。我最终得到了如下所示的代码(C# 绑定):
if (!(driver is FirefoxDriver))
{
new WebDriverWait(driver, TimeSpan.FromSeconds(10)).Until(
d => d.FindElement(By.Id(someDynamicDiv)).Size.Height > initialSize);
}
如果您无法轻松查询动画或任何其他因素,您可以使用等待元素静止的“通用”方法:
var prevLocation = new Point(Int32.MinValue, Int32.MinValue);
int stationaryCount = 0;
int desiredStationarySamples = 6; //3 seconds in total since the default interval is 500ms
return new WebDriverWait(driver, timeout).Until(d =>
{
var e = driver.FindElement(By.Id(someId));
if (e.Location == prevLocation)
{
stationaryCount++;
return stationaryCount == desiredStationarySamples;
}
prevLocation = e.Location;
stationaryCount = 0;
return false;
});
我遇到了这个,因为这个元素上有一个加载对话框封面。我通过在使用 this 元素之前添加一个等待来简单地解决它。
try {
Thread.sleep((int) (3000));
} catch (InterruptedException e) {
//
e.printStackTrace();
}
希望这有帮助!
我在使用clj-webdriver (Selenium 的 clojure 端口)时遇到了同样的问题。为方便起见,我只是将之前的解决方案翻译成 clojure。您可以在单击之前调用此函数或进行任何操作以避免该问题。
(defn scrollTo
"Scrolls to the position of the given css selector if found"
[q]
(if (exists? q)
(let [ loc (location-once-visible q) jscript (str "window.scrollTo(" (:x loc) "," (:y loc) ")") ]
(execute-script jscript))))
我遇到了这个错误,因为我测试了悬停,然后需要单击工具提示下方的链接。解决方案是在page.find('.sp-logo').hover
之前添加click_link
以消除工具提示。
也许这不是真正干净的解决方案,但它有效:
try:
el.click()
except WebDriverException as e:
if 'Element is not clickable at point' in e.msg:
self.browser.execute_script(
'$("{sel}").click()'.format(sel=el_selector)
)
else:
raise
有趣的是,我一直在查看各种回复,没有人尝试过显而易见的事情,当然,我也没有。如果您的页面多次使用相同的 id,就像我的一样,(“newButton”,)并且您想要的不是第一个找到的,那么您很可能会收到此错误。最简单的事情(C#):
var testIt = driver.FindElements(By.Id("newButton"));
请注意,它是 FindElements,而不是 FindElement。
然后测试看看有多少结果从检索中返回。如果是第二个,则可以使用:
testit[1].Click();
或者让任何重复使用 id 的人来修复它们。
在测试了所有提到的建议后,没有任何效果。我做了这个代码。它有效,但并不漂亮
public void click(WebElement element) {
//https://code.google.com/p/selenium/issues/detail?id=2766 (fix)
while(true){
try{
element.click();
break;
}catch (Throwable e){
try {
Thread.sleep(200);
} catch (InterruptedException e1) {
e1.printStackTrace();
}
}
}
}
public void click(String css) {
//https://code.google.com/p/selenium/issues/detail?id=2766 (fix)
while(true){
try{
driver.findElement(By.cssSelector(css)).click();
break;
}catch (Throwable e){
try {
Thread.sleep(200);
} catch (InterruptedException e1) {
e1.printStackTrace();
}
}
}
}
当您使用大于 1024x768 的分辨率时,请尝试最大化浏览器。
driver.manage().window().maximize();
由于同样的原因,我也被卡了两天,实际上滚动会使其工作,因为可能是数据无法正确加载,这可能会一次又一次地导致同样的错误。
我所做的是,我随机向下滚动,一次是(0,-500),然后是(0,400),然后是(0.-600),您可以根据您的使用情况赋予这些滚动值。只需将其滚动到您要单击的内容的位置。
driver.execute_script("scrollBy(0,-500);")
sleep(5)
driver.execute_script("scrollBy(0,400);")
sleep(5)
driver.execute_script("scrollBy(0,-600);")
sleep(5)
它真的有效:)
我做了一种蛮力的点击,它对我有用。
try:
elem.click()
except:
print "failed to click"
size = elem.size
mid_of_y = int(size["height"])/2
stepts_to_do_to_left = int(size["width"])
while stepts_to_do_to_left > 0:
try:
print stepts_to_do_to_left, mid_of_y
action = webdriver.common.action_chains.ActionChains(driver)
action.move_to_element_with_offset(elem, mid_of_y, stepts_to_do_to_left)
action.click()
action.perform()
print "DONE CLICK"
break
except:
pass
如果你已经jQuery
在页面上加载,你可以执行下面的 javascript 命令:
"$('#" + element_id + "').click()"
使用 python 执行器的示例:
driver.execute_script("$('#%s').click()" % element_id)
我有同样的问题,它是由 div 和 div 内的链接之间的 id 冲突引起的。所以司机点击了 div 而不是我想要的链接。我更改了 div id,它工作正常。
前:
<div id="logout"><a id="logout" href="logoutLink">logout</a></div>
后:
<div id="differentId"><a id="logout" href="logoutLink">logout</a></div>
我遇到了同样的问题,并且显示的可见元素出现“其他元素将收到点击”错误。我发现没有其他解决方案可以使用 javascript 触发点击。
我更换了:
WebElement el = webDriver.findElement(By.id("undo-alert"));
WebElement closeButton = el.findElement(By.className("close"));
// The following throws 'Element is not clickable at point ... Other element
// would receive the click'
closeButton.click();
和:
((JavascriptExecutor) webDriver).executeScript(
"$('#undo-alert').find('.close').click();"
);
一切都很好
我有另一个错误,find_link
在 Chrome 和 Poltergeist 上无法单击带有 EM 标记和其中一些文本的 A 标记,尽管它在 Firefox 和 rack_test 中运行良好。解决方案是替换click_link(link)
为:
find('a em', text: link).click
我遇到了同样的问题,花了几个小时寻找解决方案。我尝试使用量角器单击长 ngGrid 底部的单元格。这是我的 ngGrid html 的快照:
....many rows here..
<!- row in renderedRows ->
<!- column in renderedColumns ->
<div ...> <a ngclick="selectRow(row)"...>the test link 100000</a>...
....
所有点击功能都不起作用。解决方案是在元素的当前范围内使用评估:
element(by.cssContainingText("a", "the test link 100000"))
.evaluate("selectRow(row)")
在 Visual Studio 2013 中,如果启用 BrowserLink - 它会在屏幕底部显示 BrowserLink 导航栏。如果您要单击的项目位于该导航栏后面,则会出现错误。禁用 BrowserLink 为我解决了这个问题。
在尝试单击页面上的一个单选按钮时,我遇到了同样的异常。我在 Javascript 下使用并使用 IJavaScriptExecutor 执行。C# 示例
string script=" function clickCharity() {"+
"var InputElements = document.getElementsByName('Charity');"+
"for (i=0; i<InputElements.length; i++){"+
"if(InputElements[i].getAttribute('value') == 'true')"+
"{"+
"InputElements[i].click();"+
"}"+
"}"+
"}";
var js=WebDriver as IJavaScriptExecutor;
js.ExecuteScript(script);
你可以用 JS 模拟点击:
public void click(WebElement element) {
JavascriptExecutor js =(JavascriptExecutor)driver;
js.executeScript("document.elementFromPoint(" + element.getLocation().x + "," + element.getLocation().y + ").click();");
}
代替
webdriver.findElement(By.id("id1")).click();
尝试使用
click(By.id("id1"));
void click(final By byLocator) {
waitFor(new ExpectedCondition<Boolean>() {
@Override
public Boolean apply(WebDriver driver) {
WebElement element = driver.findElement(byLocator);
if (element.isDisplayed()) {
try {
element.click();
return true;
} catch (Exception e) {
e.printStackTrace();
}
}
return false;
}
@Override
public String toString() {
return "Element located " + byLocator + " clicked";
}
});
}
单击 Angular Material 菜单中的按钮时,我遇到了这个确切的问题。每当我点击菜单内的按钮时,.cdk-overlay-pane
都会收到点击。解决方法是增加z-index
菜单内的按钮个数。
.cdk-overlay-pane button {
z-index: 1001;
}
如果您在模态(弹出)中遇到此问题,请注意,可能是在当前顶级模态下方存在具有相同属性的另一个元素。这让我大吃一惊,只需增加选择器的特异性以将范围缩小到您仅尝试单击的模态范围。
我面临同样的问题,我使用了延迟,它在我身边工作得很好。页面正在刷新并获取其他定位器。
Thread.sleep(2000);
Click(By.xpath("//*[@id='instructions_container']/a"));
在 Drupal 中使用Selenium时:
// Get element.
$element = $this->driver->getElement('xpath=//input');
// Get screen location.
$location = $element->getLocation();
// To make sure that Chrome correctly handles clicking on the elements
// outside of the screen, we must move the cursor to the element's location.
$this->driver->moveCursor($location['x'], $location['y']);
// Optionally, set some sleep time (0.5 sec in the example below) if your
// elements are visible after some animation.
time_nanosleep(0, 500000000);
// Click on the element.
$element->click();
我遇到了这个问题,它似乎是(在我的情况下)通过单击一个在单击的元素前面弹出一个 div 的元素引起的。我通过将我的点击包裹在一个大的'ol try catch块中来解决这个问题。
在 Rselenium 中,当链接位于顶部窗口边框时,代码多次成功使用时会发生这种情况。简单的解决方案是使用 sendKeysToElement() 如下。
if (unlist(webElem$isElementDisplayed())) {
webElem$sendKeysToElement(list(key = "up_arrow")) # Add "up arrow"..
webElem$clickElement() # ... before $clickElement
如果您在 conf.js 文件中使用以下行,请将其注释掉并重试
browser.ignoreSynchronization = true;
如果您尝试单击 ainput
或button
即,也会发生disabled
这种情况,在这种情况下,没有任何内容与元素重叠,但它不可单击。
这可能对使用 WebdriverIO 的人有所帮助:
function(){
var runInBrowser = function(argument) {
argument.click();
};
var elementToClickOn = browser.$('element');
browser.execute(runInBrowser, elementToClickOn);
}
来源:https ://www.intricatecloud.io/2018/11/webdriverio-tips-element-wrapped-in-div-is-not-clickable/
可能有很多因素会引发此错误。首先,在 selenium webdriver 捕获元素之后,dom 可能会发生变化,或者元素中使用的所有 java 脚本在捕获元素之前没有成功加载。要解决这个问题,我们需要使用 javascript 等待或 ajax 等待,如下所示。
wait = new WebDriverWait(driver, 30);
wait.until((ExpectedCondition<Boolean>) wd -> ((JavascriptExecutor) wd).executeScript("return document.readyState").equals("complete"));
e_driver = new EventFiringWebDriver(driver);
其次,大多数提供软件质量保证服务的公司的工程师都尝试使用 java 脚本执行器进行点击操作。
如果这也不起作用,则使用 Actions 类执行操作。
WebDriverWait wait = new WebDriverWait(driver, TimeSpan.FromSeconds(15));
wait.Until(SeleniumExtras.WaitHelpers.ExpectedConditions.ElementToBeClickable(By.<Id or anything>));
希望这可以帮助。
就我而言,它在 Firefox 中有效,但在 Chrome 中失败。在 Chrome 中,它在将 Chrome 驱动程序版本更新到最新后得到修复。