网站制作的地方,wordpress表单设计,石狮市住房和城乡建设局网站,昆明网站建设方案策划shadow-root是前端的特殊元素节点#xff0c;其使用了一个叫做shadowDOM的技术做了封装#xff0c;shadowDOM的作用可以理解为在默认的DOM结构中又嵌套了一个DOM结构#xff08;和iframe有点类似#xff0c;只不过iframe内嵌的是HTML#xff09;#xff0c;我们遇见shado…shadow-root是前端的特殊元素节点其使用了一个叫做shadowDOM的技术做了封装shadowDOM的作用可以理解为在默认的DOM结构中又嵌套了一个DOM结构和iframe有点类似只不过iframe内嵌的是HTML我们遇见shadow-root元素时注意需要切换才能定位其内部元素。
在做web自动化有一些特殊元素是在shadow-root节点下面的如果通过常规的xpath或者其他的定位方式是定位不到对应元素的比如下面的页面 为什么shadow-root节点下的元素定位不到呢
shadow-root是前端的特殊元素节点其使用了一个叫做shadowDOM的技术做了封装shadowDOM的作用可以理解为在默认的DOM结构中又嵌套了一个DOM结构和iframe有点类似只不过iframe内嵌的是HTML内嵌的DOM结构默认是隐藏的所以我们如果想要在shadow-root底下的DOM中定位元素那么就需要进行切换。
解决方案
使用JavaScript操作打开F12调试窗口-进入console控制台
输入如下代码
document.querySelector(wujie-app).shadowRoot.querySelector(button[classel-button])1
效果如下 Step1先去找到shadow-root的宿主节点对应的是wujie-app
Step2使用shadowRoot方法进行切换
Step3在shadowDOM中再通过定位方法进行元素查找
另一种傻瓜式解决方案
如果不知道JavaScript如何写可以直接在元素上通过右键 - Copy - Copy JS Path 同样也可以定位到对应元素。
在Python中通过Selenium WebDriver调用execute_script方法执行JS代码即可
driver.execute_script(document.querySelector(wujie-app).shadowRoot.querySelector(\button[classel-button]\))1
注意字符串里面的单双引号嵌套的情况下需要进行转义。 总结
感谢每一个认真阅读我文章的人
作为一位过来人也是希望大家少走一些弯路如果你不想再体验一次学习时找不到资料没人解答问题坚持几天便放弃的感受的话在这里我给大家分享一些自动化测试的学习资源希望能给你前进的路上带来帮助。 软件测试面试文档
我们学习必然是为了找到高薪的工作下面这些面试题是来自阿里、腾讯、字节等一线互联网大厂最新的面试资料并且有字节大佬给出了权威的解答刷完这一套面试资料相信大家都能找到满意的工作。 视频文档获取方式 这份文档和视频资料对于想从事【软件测试】的朋友来说应该是最全面最完整的备战仓库这个仓库也陪伴我走过了最艰难的路程希望也能帮助到你以上均可以分享点下方小卡片即可自行领取。