トップページ > Selenium API(逆引き) > 【Java】isDisplayed

【Java】isDisplayed・・・要素が表示されているか判定する

【PR】業界トップクラスの「高単価報酬」「低マージン」を実現!レバテックフリーランス

要素に対して「isDisplayed」を実行することで要素がWebページ上に表示されているか調べることが出来ます。

「isDisplayed」はstyle属性で非表示になっている場合にFalseが返されます。

下記のサンプルでは、ユーザ名テキストボックスとパスワードテキストボックスの要素を取得し、「isDisplayed」を実行しています。パスワードテキストボックスは、javascriptで非表示の処理を実施している為、Falseが返されるという結果になっています。

説明

◆メソッド
  ・boolean isDisplayed()
◆使用形態
  ・element.isDisplayed()
◆備考
  ・要素が表示されている場合はTrueを返し、非表示の場合はFalseを返す
◆関連項目
  ・要素が有効になっているか判定する
  ・要素が選択されているか判定する

サンプル

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.chrome.ChromeDriver;

public class WebTest{
  public static void main(String[] args){
    //Chrome制御のためChromeDriverのパスを指定
	System.setProperty("webdriver.chrome.driver",
		                            "D:\\AutoTest\\chromedriver.exe");
	//Chromeを起動する
	WebDriver driver = new ChromeDriver();
    //指定したURLに遷移する<図1>
    driver.get("file://D:/AutoTest/isDisplayed.html");
    //ユーザ名テキストボックスの要素を取得
    WebElement elemUser = driver.findElement(By.id("user01"));
    //パスワードテキストボックスの要素を取得
    WebElement elemPass = driver.findElement(By.id("pass01"));
    //ユーザ名テキストボックスの表示状態を判定
    System.out.println(elemUser.isDisplayed());
    //パスワードテキストボックスの表示状態を判定
    System.out.println(elemPass.isDisplayed());
  }
}
※selenium version 4.1.4で動作確認をしています

実行結果

true
false
isDisplayed

isDisplayed.html<図1>

<!DOCTYPE html>
<html lang="ja">
    <head>
        <title>isDisplayed</title>
    </head>
    <body>
        <p><label for='user01'>ユーザ名:</label><input type="text" id="user01" value="user"></p>
        <p><label for='pass01'>パスワード:</label><input type="text" id="pass01"></p>
        <script>
            function hideBtn(){
                var txtElm = document.getElementById("pass01");
                txtElm.style.visibility = "hidden";
            }
            hideBtn();
        </script>
    </body>
</html>

動画デモ

※字幕をONにすると解説のテロップが表示されます※


Fatal error: Uncaught Google_Service_Exception: Error calling GET https://www.googleapis.com/analytics/v3/data/ga?ids=ga%3A138132118&start-date=7daysAgo&end-date=yesterday&metrics=ga%3Apageviews&dimensions=ga%3ApageTitle%2C+ga%3ApagePath&sort=-ga%3Apageviews&max-results=1000: (502) <!DOCTYPE html> <html lang=en> <meta charset=utf-8> <meta name=viewport content="initial-scale=1, minimum-scale=1, width=device-width"> <title>Error 502 (Server Error)!!1</title> <style> *{margin:0;padding:0}html,code{font:15px/22px arial,sans-serif}html{background:#fff;color:#222;padding:15px}body{margin:7% auto 0;max-width:390px;min-height:180px;padding:30px 0 15px}* > body{background:url(//www.google.com/images/errors/robot.png) 100% 5px no-repeat;padding-right:205px}p{margin:11px 0 22px;overflow:hidden}ins{color:#777;text-decoration:none}a img{border:0}@media screen and (max-width:772px){body{background:none;margin-top:0;max-width:none;padding-right:0}}#logo{background:url(//www.google.com/images/branding/googlelogo/1x/googlelog in /home/users/1/monda-muki/web/seleniumqref.com/google-api-php-client-1-master/src/Google/Http/REST.php on line 110