当前位置: 首页 > news >正文

Selenium中隐式等待(Implicit Wait)和显式等待(Explicit Wait)的区别

Selenium中隐式等待(Implicit Wait)和显式等待(Explicit Wait)的区别


1)本质区别:它们“等的对象”不一样

隐式等待等的是:

**元素查找(findElement / findElements)**这件事。

也就是说,隐式等待只在你调用driver.findElement(...)这一刻生效:在超时时间内不断重试“查找元素”,找到就返回,找不到就一直试到超时抛异常。

显式等待等的是:

某个明确条件(ExpectedCondition)成立

条件可以是“元素可见/可点击/存在”“URL 变了”“文本出现了”“alert 出现了”等等——它不局限于“找元素”。

这就是为什么你说的那句成立:隐式等待无法等待 alert,因为 alert 不是通过 findElement 找到的 DOM 元素。


2)作用范围:全局 vs 局部

隐式等待:全局配置,一次设置长期生效

driver.manage().timeouts().implicitlyWait(Duration.ofSeconds(10));

设置后,只要这个driver还在,后续每一次findElement都会带着这 10 秒的“自动重试”。

显式等待:局部使用,想等哪就等哪

WebDriverWaitwait=newWebDriverWait(driver,Duration.ofSeconds(10));wait.until(ExpectedConditions.visibilityOfElementLocated(By.id("kw")));

你在需要的地方才写一段等待逻辑,不需要的地方不影响。


3)能等什么:隐式等待“只等元素”,显式等待“啥都能等(条件允许)”

隐式等待能等的典型东西

  • 页面元素出现(presence)
  • 页面元素最终能被找到(findElement 成功)

但注意:隐式等待只保证“找到元素”,不保证它:

  • 可见(visible)
  • 可点击(clickable)
  • 不被遮挡
  • 文本已经渲染完

所以隐式等待经常出现“找到了但点不了/拿不到文本”的情况。

显式等待能等的典型东西(举几个高频)

  • 元素可点击:elementToBeClickable
  • 元素可见:visibilityOfElementLocated
  • 元素存在于 DOM:presenceOfElementLocated
  • 文本出现/变为某值:textToBePresentInElementLocated/textToBe
  • URL 变化:urlContains/urlToBe
  • 弹窗出现:alertIsPresent()

示例:等待 alert 出现并接受

WebDriverWaitwait=newWebDriverWait(driver,Duration.ofSeconds(10));Alertalert=wait.until(ExpectedConditions.alertIsPresent());alert.accept();

这段是隐式等待做不到的,因为它根本不走findElement


4)对“找不到元素”行为的影响:异常类型与重试方式

  • 隐式等待:只要findElement没找到,就反复重试;最终超时会抛NoSuchElementException(常见表现)
  • 显式等待:内部轮询条件;最终超时会抛TimeoutException(更像“条件没满足”)

这点在定位问题时很有用:
看到TimeoutException通常说明你等的条件一直没成立,而不是“元素压根不存在”。


5)为什么不建议混用:时间会变得“不可预测”

当你同时开了:

  • 隐式等待 10 秒
  • 显式等待 10 秒

显式等待内部也会反复调用元素查找/条件判断,而这些查找又会被隐式等待“拖住”。最终你以为最多等 10 秒,实际可能更久(常见表现:超时明显大于显式等待设置值)。

实战上更稳的策略通常是:

  • 主用显式等待(精确、可控)
  • 隐式等待要么不用,要么设很小(例如 0~1 秒)避免干扰

6)典型场景对比:你会在哪踩坑

场景 A:元素是动态渲染的(ajax)

  • 隐式等待:能帮你等到“元素出现在 DOM”
  • 显式等待:不仅能等到出现,还能等到“可见/可点/文本更新”

场景 B:点击后出现 alert

  • 隐式等待:无效(alert 不是 DOM 元素)
  • 显式等待:alertIsPresent()一把梭

场景 C:元素存在但被遮挡(弹层/加载动画)

  • 隐式等待:可能找得到但点不了,直接ElementClickInterceptedException
  • 显式等待:可以等到elementToBeClickable(但如果一直被遮挡也会超时)

7)总结

  • 隐式等待:给findElement加“全局重试”,简单但粗糙,等不到 alert,也不擅长等“可点击/可见/文本更新”。
  • 显式等待:按条件等,颗粒度细、可控,能等元素状态、URL、文本、alert等,是写稳定脚本的主力工具。
http://www.jsqmd.com/news/275173/

相关文章:

  • 大数据毕设项目推荐-基于django的直播带货商品数据分析可视化系统基于django大数据在直播带货商品选品中的应用【附源码+文档,调试定制服务】
  • SSM277课程在线考试组卷管理系统vue
  • macOS部署docker容器的坑点
  • SSM280的课程智能组卷考试系统vue
  • SSM281的垃圾分类系统vue商城,礼品,考试
  • 智能体部署架构:突破性能极限的关键!
  • 大数据毕设选题推荐:基于python大数据的国内自然地震数据可视化分析系统基于python的灾情数据可视化系统【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 【毕业设计】基于django大数据在直播带货商品选品中的应用(源码+文档+远程调试,全bao定制等)
  • 计算机大数据毕设实战-基于python的洪涝灾情数据可视化系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 【课程设计/毕业设计】基于django大数据在直播带货商品选品中的应用直播带货商品数据分析可视化系统【附源码、数据库、万字文档】
  • 大数据领域内存计算:构建实时数据处理的高效平台
  • 即插即用系列 | CVPR 2025 AmbiSSL:首个注释模糊感知的半监督医学图像分割框架
  • 大数据计算机毕设之基于python的灾情数据可视化系统洪水预测系统 自然灾害预测可视化(完整前后端代码+说明文档+LW,调试定制等)
  • 大模型本地部署,小号的vLLM来了!
  • 大数据毕设项目:基于python的灾情数据可视化系统(源码+文档,讲解、调试运行,定制等)
  • Kuikly 框架架构与目录导览(HarmonyOS 视角)
  • 速通秘籍!提示工程架构师上下文工程跨模态信息融合技术
  • 【课程设计/毕业设计】基于python大数据的睡在地震数据可视化分析系统基于python的灾情数据可视化系统【附源码、数据库、万字文档】
  • 我是AI应用架构师,给某制造企业做算力规划的过程,全记录
  • 群晖 WebDAV+cpolar 让 NAS 文件走到哪用到哪
  • 提示工程项目成本效益分析:从需求调研到成果交付的全流程指导!
  • 计算机大数据毕设实战-基于django的电子产品电商平台主数据管理系统基于django的电子产品电商平台主数据管理系统【完整源码+LW+部署说明+演示视频,全bao一条龙等】
  • 2026项目管理工具推荐:7款免费版能做什么、卡在哪里
  • 大数据毕设选题推荐:基于django的电子产品电商平台主数据管理系统基于django的电子产品电商平台主数据管理系统【附源码、mysql、文档、调试+代码讲解+全bao等】
  • 第 471 场周赛Q1——3712. 出现次数能被 K 整除的元素总和
  • 西电Latex论文模板使用经验总结
  • 【AI应用开发工程师】-分享Java 转 AI正确思路
  • 【AI应用开发工程师】-分享2026年转型AI应用开发工程师经验
  • 深度测评研究生必备9款AI论文平台:开题文献综述全解析
  • 实用指南:Pandas 高级教程:解锁数据分析的强大潜能