等待图像完全加载Selenium WebDriver

时间:2017-03-07 18:38:19

标签: java selenium selenium-webdriver webdriver

我看到有一个问题:Selenium-Webdriver Ruby --> How to wait for images to be fully loaded after click

但似乎没有人直接回答:我需要等待图像完全加载,而不是仅仅使用selenium WebDriver呈现在DOM中。我该怎么办?目前我正在使用

  public static void waitUntilVisible(WebDriver webDriver, By locator) {
    WebDriverWait driverWait = new WebDriverWait(webDriver, TIMEOUT);
    driverWait.until(visibilityOfElementLocated(locator));
  }

使用

  /**
   * An expectation for checking that an element is present on the DOM of a page and visible.
   * Visibility means that the element is not only displayed but also has a height and width that is
   * greater than 0.
   *
   * @param locator used to find the element
   * @return the WebElement once it is located and visible
   */
  public static ExpectedCondition<WebElement> visibilityOfElementLocated(
    final By locator) {
    return new ExpectedCondition<WebElement>() {
      @Override
      public WebElement apply(WebDriver driver) {
        try {
          return elementIfVisible(findElement(locator, driver));
        } catch (StaleElementReferenceException e) {
          return null;
        }
      }

      @Override
      public String toString() {
        return "visibility of element located by " + locator;
      }
    };
  }

但是如果图像已经有高度和宽度,即使图像没有加载,它也可能被视为可见

1 个答案:

答案 0 :(得分:3)

你可以执行一些javascript来询问DOM。具体而言,HTMLImageElementcomplete属性。

public static void waitUntilVisible(WebDriver webDriver, By locator) {
    WebDriverWait driverWait = new WebDriverWait(webDriver, TIMEOUT);
    WebElement el = webDriver.findElement(locator);
    driverWait.until(
        new Predicate<WebDriver>() {
            public boolean apply(WebDriver driver) {
                return ((JavascriptExecutor)driver).executeScript("return arguments[0].complete", el);
            }
        }
    );
}

但请注意complete

  

返回一个布尔值,如果浏览器已完成提取,则为true   图像,无论成功与否。如果图像也显示真实   没有src值。