一:未切换frame
学过前端的同学都知道,前端页面大多使用了html的嵌套(使用了iframe),即一个完整的html被放到了另外一个html内部,此时我们访问的url是外部html对应的url,然而我们需要寻找的是内部的html的控件,这个时候我们在外部的html自然找不到控件
解决方案:切换iframe
1,通过id切换:
chrome.switch_to.frame("mainFrame")
2,先找到ifrome,再切换:
element = chrome.find_element_by_id("mainFrame")
chrome.switch_to.frame(element)
3,通过序号切换:
chrome.switch_to.frame(0)
二:动态加载页面
很多时候我们需要访问的页面是动态变化的,比如最经典的场景是我们必须把鼠标悬停在某处才能展示弹框,这个时候我们直接去定位这个弹框是定位不到的,我们就需要去模拟让这个动态效果触发,只有先触发了动态效果,我们才能定位到控件
解决方案:模拟操作触发动态效果,触发后再定位
1,鼠标悬停:
#定位到要悬停的元素
move = driver.find_element_by_id("xx")
对定位到的元素执行悬停操作
#ActionChains(driver).move_to_element(move).perform()
三:控件设置了不可点击属性
在html的中可通过css设置不可点击属性,当发现在css 中有pointer-events: none的时候;那么我们就不能够点击这个标签,我们可以尝试点击他的子标签或者父标签,此时一样可以达到相同的目的