selenium操作iframe元素的方法

来源:网络 文章列表 2019-07-17 8
frame标签有frameset、frame、iframe三种,frameset跟其他普通标签没有区别,不会影响到正常的定位,而frame与iframe对selenium定位而言是一样的,selenium有一组方法对frame进行操作。

frame标签有frameset、frame、iframe三种,frameset跟其他普通标签没有区别,不会影响到正常的定位,而frame与iframe对selenium定位而言是一样的,selenium有一组方法对frame进行操作。

总结:frameset不用切,frame/iframe需要层层切!!!

一、怎么切到iframe中(switch_to.frame())

selenium提供了switch_to.frame()方法来切换iframe

driver.switch_to.frame(reference)

reference是传入的参数,用来定位frame,可以传入id、name、index以及selenium的WebElement对象,假设有如下HTML代码 index.html:

<!DOCTYPE html>
<html>
<head>
    <title></title>
</head>
<body>
<div id="wrap">
   <iframe src="1.html" id="frame1" name="myframe"></iframe>
</div>
</body>
</html>

想要定位其中的iframe并切进去,可以通过如下代码:

# 用iframe的index来定位
driver.switch_to.frame(0)
# 用iframe的id来定位
driver.switch_to.frame('frame1')
# 用iframe的name来定位
driver.switch_to.frame('myframe')
# 用webElement对象来定位
iframeTag = driver.find_element_by_xpath('//div[@id="wrap"]/iframe')
driver.switch_to.frame(iframeTag)

通常采用id和name就能够解决绝大多数问题。但有时候frame并无这两项属性,则可以用index和WebElement来定位:

    a、index从0开始,传入整型参数即判定为用index定位,传入str参数则判定为用id/name定位;

    b、WebElement对象,即用find_element系列方法所取得的对象,我们可以用tag_name、xpath等来定位frame对象;

二、从frame中切回主文档(switch_to.default_content())

切到frame中之后,我们便不能继续操作主文档的元素,这时如果想操作主文档内容,则需切回主文档。

driver.switch_to.default_content()

三、嵌套frame的操作(switch_to.parent_frame())

有时候我们会遇到嵌套的frame,如下:

<iframe id="frame1">
    <iframe id="frame2"></iframe>
</iframe>

1、从主文档切到frame2,一层层切进去

driver.switch_to.frame('frame1')
driver.switch_to.frame('frame2')

2、从frame2再切回frame1,这里selenium给我们提供了一个方法能够从子frame切回到父frame,而不用我们切回主文档再切进来。

 # 如果当前已是主文档,则无效果
 driver.switch_to.parent_frame()

有了parent_frame()这个相当于后退的方法,我们可以随意切换不同的frame,随意的跳来跳去了。

所以只要善用以下三个方法,遇到frame分分钟搞定:

driver.switch_to.iframe()
driver.switch_to.parent_frame()
driver.switch_to.default_content()

 

腾讯云限量秒杀

1核2G 5M 50元/年 2核4G 8M 74元/年 4核8G 5M 818元/年 CDN流量包 100GB 9元

版权声明

本站部分原创文章,部分文章整理自网络。如有转载的文章侵犯了您的版权,请联系站长删除处理。如果您有优质文章,欢迎发稿给我们!联系站长:
愿本站的内容能为您的学习、工作带来绵薄之力。

评论

  • 随机获取
点击刷新
精彩评论

友情链接