WebDriver拾级而上·之五 iframe的处理

本文介绍如何使用Selenium WebDriver处理网页中的iframe元素。通过正确切换上下文,可以实现在iframe内部定位元素并进行操作。
有时候我们在定位一个页面元素的时候发现一直定位不了,反复检查自己写的定位器没有任何问题,代码也没有任何问题。这时你就要看一下这个页面元素是否在一个iframe中,这可能就是找不到的原因之一。
如果你在一个default content中查找一个在iframe中的元素,那肯定是找不到的。反之你在一个iframe中查找另一个iframe元素或default content中的元素,那必然也定位不到。
selenium webdriver中提供了进入一个iframe的方法:
<wbr><wbr><wbr></wbr></wbr></wbr>WebDriver org.openqa.selenium.WebDriver.TargetLocator.frame(String nameOrId)
也提供了一个返回default content的方法:
<wbr><wbr><wbr></wbr></wbr></wbr>WebDriver org.openqa.selenium.WebDriver.TargetLocator.defaultContent()
这样使我们面对iframe时可以轻松应对。
switch_to方法会new <wbr>1个TargetLocator对象,使用该对象的frame方法可以将当前识别的”主体”移动到需要定位的frame上去。</wbr><wbr></wbr>

以下面的html代码为例,我们看一下处现iframe。

这个2个页面放桌面
Html代码
main.html
<html>
<wbr><wbr>&lt;head&gt;</wbr></wbr>
<wbr><wbr><wbr><wbr>&lt;title&gt;FrameTest&lt;/title&gt;</wbr></wbr></wbr></wbr>
<wbr><wbr>&lt;/head&gt;</wbr></wbr>
<wbr><wbr>&lt;body&gt;</wbr></wbr>
<div id = "id1">this is a div!</div>
<wbr><wbr><wbr><wbr>&lt;iframe id = "<span style="color:#0002FF; word-wrap:normal; word-break:normal; line-height:21px">frame</span>" <wbr>frameborder="0" scrolling="no" style="left:0;position:absolute;" src = "frame.html"&gt;&lt;/iframe&gt;</wbr></wbr></wbr></wbr></wbr>
<wbr><wbr>&lt;/body&gt;</wbr></wbr>
</html>

frame.html
<html>
<wbr><wbr>&lt;head&gt;</wbr></wbr>
<wbr><wbr><wbr><wbr>&lt;title&gt;this is a frame!&lt;/title&gt;</wbr></wbr></wbr></wbr>
<wbr><wbr>&lt;/head&gt;</wbr></wbr>
<wbr><wbr>&lt;body&gt;</wbr></wbr>
<div id = "div2">this is a frame,too!</div>
<label>input:</label>
<input id = "input2" value='frame VALUE'>a frame</input>
<wbr><wbr>&lt;/body&gt;</wbr></wbr>
</html>

Java代码
package com.test;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.chrome.ChromeDriver;


public class Test_frame {
public static void main(String[] args) {

String url = "file:///C:/Documents and Settings/fei yong/桌面/main.html";
<wbr><wbr>//打开chrome</wbr></wbr>
<wbr><wbr>WebDriver dr = new ChromeDriver();</wbr></wbr>
<wbr><wbr><wbr><wbr>dr.get(url);</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr><wbr></wbr></wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//在default content定位id="id1"的div</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>dr.findElement(By.id("id1"));</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//此时,没有进入到id="frame"的frame中时,以下两句会报错</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//dr.findElement(By.id("div1"));//报错</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//dr.findElement(By.id("input1"));//报错</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//进入id="frame"的frame中,定位id="div1"的div和id="input1"的输入框。</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr><span style="color:#FF0000; word-wrap:normal; word-break:normal; line-height:21px">dr.switchTo().frame("frame");</span></wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>dr.findElement(By.id("div2"));</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>dr.findElement(By.id("input2"));</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>System.out.println("div2.getTagName:"+dr.findElement(By.id("div2")).getTagName()+";");</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>System.out.println("input2.getTagName:"+dr.findElement(By.id("input2")).getTagName());</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>System.out.println("input2.getText:"+dr.findElement(By.id("input2")).getText());</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr><wbr></wbr></wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//此时,没有跳出frame,如果定位default content中的元素也会报错。</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//dr.findElement(By.id("id1"));//报错</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>//跳出frame,进入default content;重新定位id="id1"的div</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr><span style="color:#FF0000; word-wrap:normal; word-break:normal; line-height:21px">dr.switchTo().defaultContent();</span></wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>dr.findElement(By.id("id1"));</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>System.out.println("id1.getText:"+dr.findElement(By.id("id1")).getText());</wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr><wbr></wbr></wbr></wbr></wbr></wbr>
<wbr><wbr><wbr><wbr>dr.quit();</wbr></wbr></wbr></wbr>
}
}

页面输出:
WebDriver拾级而上路之五<wbr>iframe的处理
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值