selenium-webdriver 使用WebDriverWait显示等待ajax交互

本文介绍如何在selenium版本2.44.0中利用WebDriverWait进行显示等待,有效处理网页上的AJAX异步加载情况,确保在不重新加载页面的情况下正确获取操作结果。
摘要由CSDN通过智能技术生成


使用selenium版本为2.44.0

现在很多网站都是使用ajax进行交互,常见就是某个操作后,等待结果展示,但是不会重新加载页面,这个时候不能使用原始的等待方法:

webDriver.manage().timeouts().pageLoadTimeout(seconds, TimeUnit.SECONDS);

现在只能不断判断某个元素是否出现,出现了则定义为页面交互完毕。
自己封装了几个方法,亲测可用。
1.判断元素是否存在(是否存在DOM结构中)
2.判断元素是否显示(存在于DOM结构且为可视状态)</p><p>3.判断元素是否不隐藏(不存在与DOM结构中 或者存在于DOM结构中但为不可视状态)
代码解析:WebDriverWait 会每个500ms不断的执行until 方法,直到返回的内容为true 或者非null ,超过时间则抛TimeOut异常,程序进行捕捉然后定义为false。


   /**
     * 判断元素是否在指定时间内存在。
     * 只要元素出现在dom结构中(不管属性是显示还是隐藏) 马上返回true
     * 在指定时间仍不存在与dom结构则返回false。
     * 适用于ajax
     * 
     * @param by 元素
     * @param seconds 指定秒数
     * @return 出现返回true 否则返回false
     */
    public static boolean waitForElementPresence(final By by, int seconds) {
        try {
            new WebDriverWait(webDriver, seconds).until(ExpectedConditions.presenceOfElementLocated(by));
            return true;
        } catch (Exception e) {
            return false;
        }
    }

    /**
     * 判断元素在指定时间是否显示
     * 元素是否在指定时间内显示(存在dom结构且属性为显示)马上返回true
     * 如果到指定时间仍未显示(不存在与dom结构 或者存在于dom结构但属性为‘隐藏’)则返回false
     * 适用于ajax
     * 
     * @param by 元素
     * @param seconds 指定秒数
     * @return 出现返回true 否则返回false
     */
    public static boolean waitForElementVisible(final By by, int seconds) {
        try {
            new WebDriverWait(webDriver, seconds).until(ExpectedConditions.visibilityOfElementLocated(by));
            return true;
        } catch (Exception e) {
            return false;
        }
    }

    /**
     * 判断元素是否在指定时间内隐藏或者消失
     * 如果元素消失(不存在于dom结构 或者属性为 ‘隐藏’)则立刻返回true
     * 如果指定时间后元素仍然存在(存在于dom结构且属性为‘显示’)则返回false
     * 
     * @param by 元素
     * @param seconds 秒数
     * @return
     */
    public static boolean waitForElementInvisible(final By by, int seconds) {
        try {
            new WebDriverWait(webDriver, seconds).until(ExpectedConditions.invisibilityOfElementLocated(by));
            return true;
        } catch (Exception e) {
            return false;
        }
    }


-------



  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值