使用 Selenium 计算 WebTable 中的隐藏行

Count Of Hidden Rows in WebTable By Using Selenium

我在应用程序中有一个隐藏按钮,可以隐藏网络上的重复数据条目 table。我一直在尝试捕获隐藏行的数量。请参阅下面的 html 和我的方法。我尝试过的每一次尝试都以 0 结束。但是,结果应该是 2.

HTML 代码:

<tbody>
<tr role = "row" class="odd">...<tr/>
<tr role = "row" class="even">...<tr/>
<tr role = "row" class="odd">...<tr/>
<tr role = "row" class="even">...<tr/>
<tr role = "row" class="odd">...<tr/>
<tr role = "row" class="odd duplicate" style="display: none;" >...<tr/>
<tr role = "row" class="even duplicate" style="display: none;" >...<tr/>
</tbody>

def getInvisibleTableRowCount()
{
    WebDriver driver = DriverFactory.getWebDriver()
    WebElement table = driver.findElement(By.xpath("//*[@id='DataTables_Table_0']/tbody"))
    List<WebElement> rows_table= table.findElements(By.cssSelector("[display=none]"));
    int rowSize = rows_table.size();
    return rowSize;
}

这是我的另一个尝试:

def getInvisibleTableRowCount()
{
    WebDriver driver = DriverFactory.getWebDriver()
    WebElement table = driver.findElement(By.xpath("//*[@id='DataTables_Table_0']/tbody"))
    List<WebElement> rows_table= table.findElements(By.tagName("tr[not(contains(@style,'display: none;'))]"));
    int rowSize = rows_table.size();
    return rowSize;
}

如果我 运行 xpath 为 //*[@id='DataTables_Table_0']/tbody/tr[not(contains(@style,'display: none;'))] ,我可以在浏览器上找到隐藏的行。

我也试过这个:

def getInvisibleTableRowCount()
{
    WebDriver driver = DriverFactory.getWebDriver()
    WebElement table = driver.findElement(By.xpath("//*[@id='DataTables_Table_0']/tbody"))
    List<WebElement> rows_table= table.findElements(By.tagName("tr"));
    int rowSize = rows_table.size();
    for(WebElement row: rows_table)
    {
        if(row.isDisplayed()==false)
        {
            rowSize = rowSize -1; 
        }
    }
    return rowSize;
}

在@Hac 的评论后,我尝试了JQuery。我在浏览器上运行 jQuery,没问题。但是我的函数返回了一个“NULL”值。我仔细检查了注释行中提示正确的 jQuery 字符串

@Keyword
def getTableRowCountAfterHiding()
{
    def jQuery='$'+'("#DataTables_Table_0 tbody tr:visible").length'
    WebUI.comment(jQuery);
    def visibleRowCounts = new utils.ExecuteJavaScript().executeJavaScript(jQuery);
    return visibleRowCounts;
}

我将 utils 定义为 运行 JS,如下所示:

public class ExecuteJavaScript {
    //This keyword is designed to execute JS.
    @Keyword
    def executeJavaScript(String javascript) {
        ((JavascriptExecutor) DriverFactory.getWebDriver()).executeScript(javascript)
    }
}

有效:

def getTableRowCountAfterHiding()
{   
    WebDriver driver = DriverFactory.getWebDriver()
    List<WebElement> table = driver.findElements(By.xpath("//*[@id='DataTables_Table_0']/tbody/tr[not(contains(@style,'display: none;'))]"))
    int rowSize = table.size();
    return rowSize;
}