selenium操作隐藏元素——交流帖

这篇博客主要讨论了在自动化测试中如何处理隐藏元素的问题,特别是使用Selenium时遇到的挑战。文章介绍了两种方法:通过修改HTML元素的display属性使其可见,以及利用execute_script执行JavaScript来操作隐藏元素。提供了具体的代码示例,包括改变select元素的可见性和设置元素边框颜色。此外,还提到了Arguments对象在JavaScript中的应用,以及fadeOut和fadeIn方法在元素隐藏和显示中的作用。
摘要由CSDN通过智能技术生成

                         1、对于前端隐藏元素,一直是selenium自动化定位元素的隐形杀手,

                              脚本跑到隐藏元素时位置时报各种各样的错误,可是这种隐藏的下拉

                              菜单又没有办法避免,所以非常头痛,此帖只为交流隐藏元素自动化

                              定位处理方法;

                                        处理一:html这种格式的:
                
                                        处理操作:
                   
from selenium import webdriver
from selenium.webdriver.support.select import Select
import os,time

driver = webdriver.Firefox()
file_path = 'file:///' + os.path.abspath('test.html')
driver.get(file_path)

js = 'document.querySelectorAll("select")[0].style.display="block";'
driver.execute_script(js)

sel = driver.find_element_by_tag_name('select')
Select(sel).select_by_value('opel')

time.sleep(2)

driver.quit()
                            来自虫师的解释:
                                         document.querySelectorAll("select")[0].style.display="block";
                                    document.querySelectorAll("select")  选择所有的select。
                                    [0] 指定这一组标签里的第几个。
                                   style.display="block";  修改样式的display="block" ,表示可见。
                                   执行完这句js代码后,就可以正常操作下拉框了。
                                  重点描述:
                                 2、JS方法的调用:
                                        调用js方法:execute_scrip
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值