• Selenium 遇见伪元素该如何处理?


    问题发生

    在很多前端页面中,大家会见到很多::before、::after 元素,比如【百度流量研究院】:

    比如【百度疫情大数据平台】:

     

    以【百度疫情大数据平台】为例,“累计确诊”文本并没有显示在 HTML 源代码中,如果通过常规的 xpath 元素定位方式是没办法的,因为“累计确诊”文本并不存在当前页面 dom 树中。

    如何处理?

    我们要弄清楚的是该元素的特殊之处,文本究竟存放在哪?

    其实很简单,通过 Chrome 的 F12,我们将 style 选项展示出来:

    可以看到元素的文本保存在 CSS 样式里面,通过 content 属性进行设置。

    这里还有个小问题:文本根本对不上呢?

    因为这里使用了 Unicode 编码,使用在线的 Unicode 编码转换工具即可看到

     

    ::after 元素也是同理,这种性质的元素我们称之为伪元素:

    之所以被称为伪元素,是因为他们不是真正的页面元素,HTML 没有对应的元素,但是其所有用法和表现行为与真正的页面元素一样,可以对其使用诸如页面元素一样的 CSS 样式,表面上看上去貌似是页面的某些元素来展现,实际上是 CSS 样式展现的行为,因此被称为伪元素。

    一、伪元素的定位

    由于伪元素是通过 CSS 样式展现的行为,所以我们可以通过 CSS 样式选择器来进行定位,以“百度疫情大数据为例”:

    1. 先定位伪元素的父元素:div.Virus_1-1-318_3W7bs_
    2. 再定位到伪元素本身:div.Virus_1-1-318_3W7bs_>label

    二、伪元素文本的获取

    有些情况下我们需要获取到文本信息,其中伪元素的文本主要是通过 content 属性设置,我们可以通过 JavaScript 可以进行提取:

    1. window.getComputedStyle(document.querySelector('.样式'),':before').getPropertyValue('content')
    2. window.getComputedStyle(document.querySelector('.样式'),':after').getPropertyValue('content')

     

    Selenium 中调用 JavaScript:

    1. JavascriptExecutor jsExecutor = (JavascriptExecutor) driver;
    2. jsExecutor.executeScript("window.getComputedStyle(document.querySelector('.Virus_1-1-318

    最后:下面是配套学习资料,对于做【软件测试】的朋友来说应该是最全面最完整的备战仓库,这个仓库也陪伴我走过了最艰难的路程,希望也能帮助到你!【100%无套路免费领取】

    软件测试面试小程序

    被百万人刷爆的软件测试题库!!!谁用谁知道!!!全网最全面试刷题小程序,手机就可以刷题,地铁上公交上,卷起来!

    涵盖以下这些面试题板块:

    1、软件测试基础理论 ,2、web,app,接口功能测试 ,3、网络 ,4、数据库 ,5、linux

    6、web,app,接口自动化 ,7、性能测试 ,8、编程基础,9、hr面试题 ,10、开放性测试题,11、安全测试,12、计算机基础

      全套资料获取方式:点击下方小卡片自行领取即可

  • 相关阅读:
    JavaEE——SmartTomcat的使用教程与常见错误
    git——如何撤销已经push到远程的修改
    线上线下结合的经营方式 同城服务平台搭建
    AndroidStudio003--Button组件的使用,监听及事件处理
    组件化通信
    第2关:遗传算法 - 函数最优解计算
    基于单片机的IC卡门禁系统设计
    华为机试 - 模拟商场优惠打折
    【SwiftUI模块】0015、SwiftUI自定义音频播放器
    [激光器原理与应用-12]: 2022年中国激光行业总体市场规模及发展趋势预测分析
  • 原文地址:https://blog.csdn.net/weixin_57794111/article/details/133272619