Selenium + Webdriver 学习(五) frame下元素定位

有时候我们在定位一个页面元素的时候发现一直定位不了,反复检查自己写的定位器没有任何问题,代码也没有任何问题。这时你就要看一下这个页面元素是否在一个iframe中,这可能就是找不到的原因之一。如果你在一个defaultcontent中查找一个在iframe中的元素,那肯定是找不到的。反之你在一个iframe中查找另一个iframe元素或default content中的元素,那必然也定位不到。

selenium webdriver中提供了进入一个iframe的方法:

WebDriver org.openqa.selenium.WebDriver.TargetLocator.frame(StringnameOrId)

也提供了一个返回default content的方法:

WebDriver org.openqa.selenium.WebDriver.TargetLocator.defaultContent()

这样使我们面对iframe时可以轻松应对。

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

Html代码:

main.html

  1. <html>    
  2.     <head>    
  3.         <title>FrameTest</title>    
  4.     </head>    
  5.     <body>    
  6.     <div id = "id1">this is a div!</div>    
  7.         <iframe id = "frame"  frameborder="0" scrolling="no" style="left:0;position:absolute;" src = "frame.html"></iframe>    
  8.     </body>    
  9. </html>    
  10.     
<html>  
    <head>  
        <title>FrameTest</title>  
    </head>  
    <body>  
    <div id = "id1">this is a div!</div>  
        <iframe id = "frame"  frameborder="0" scrolling="no" style="left:0;position:absolute;" src = "frame.html"></iframe>  
    </body>  
</html>  
  
frame.html 
  1. <html>    
  2.     <head>    
  3.         <title>this is a frame!</title>    
  4.     </head>    
  5.     <body>    
  6.     <div id = "div1">this is a div,too!</div>    
  7.     <label>input:</label>    
  8.     <input id = "input1"></input>    
  9.     </body>    
  10. </html>    
<html>  
    <head>  
        <title>this is a frame!</title>  
    </head>  
    <body>  
    <div id = "div1">this is a div,too!</div>  
    <label>input:</label>  
    <input id = "input1"></input>  
    </body>  
</html>  
如图:



java代码:

  1. /*** This class is about Test_i\frame. 
  2. * @author annie.wang   
  3. */  
  4. package com.annie.test;  
  5.   
  6. import org.openqa.selenium.By;  
  7. import org.openqa.selenium.WebDriver;  
  8. import org.openqa.selenium.firefox.FirefoxDriver;  
  9. public class Iframe_Test {  
  10. public static void main(String[] args) {  
  11.         // TODO Auto-generated method stub   
  12.     WebDriver dr= new FirefoxDriver();  
  13.     String url="C:\\Users\\Administrator\\Desktop\\frametest\\main.html";  
  14.     dr.get(url);  
  15.     /**在default content定位id="id1"的div*/  
  16.     dr.findElement(By.id("id1"));  
  17.     //此时没有进入到id="frame"的frame 中时,以下两句会报错   
  18.     dr.findElement(By.id("div1"));//error   
  19.     dr.findElement(By.id("input1"));//error   
  20.   
  21.     }  
  22.   
  23. }  
/*** This class is about Test_i\frame.
* @author annie.wang  
*/
package com.annie.test;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.firefox.FirefoxDriver;
public class Iframe_Test {
public static void main(String[] args) {
		// TODO Auto-generated method stub
	WebDriver dr= new FirefoxDriver();
	String url="C:\\Users\\Administrator\\Desktop\\frametest\\main.html";
	dr.get(url);
	/**在default content定位id="id1"的div*/
	dr.findElement(By.id("id1"));
	//此时没有进入到id="frame"的frame 中时,以下两句会报错
	dr.findElement(By.id("div1"));//error
	dr.findElement(By.id("input1"));//error

	}

}
报错如图:(定位不到元素)


加入如下代码片段再 定位 frame下的id=“div1”和id=“input1” 就不会报错。

  1. dr.switchTo().frame("frame");  
dr.switchTo().frame("frame");

注意最后回到default content中定位,需要跳出,否则也会报错

综上所述:完整代码如下:

  1. /*** This class is about Test_i\frame. 
  2.  * @author annie.wang   
  3.  */  
  4. package com.annie.test;  
  5.   
  6. import org.openqa.selenium.By;  
  7. import org.openqa.selenium.WebDriver;  
  8. import org.openqa.selenium.WebElement;  
  9. import org.openqa.selenium.firefox.FirefoxDriver;  
  10.   
  11. public class Iframe_Test {  
  12.     public static void main(String[] args) {  
  13.         // TODO Auto-generated method stub   
  14.         WebDriver dr = new FirefoxDriver();  
  15.         String url = "C:\\Users\\Administrator\\Desktop\\frametest\\main.html";  
  16.         dr.get(url);  
  17.         /** 在default content定位id="id1"的div */  
  18.         dr.findElement(By.id("id1"));  
  19.         // 此时没有进入到id="frame"的frame 中时,以下两句会报错   
  20.         // dr.findElement(By.id("div1"));//error   
  21.         // dr.findElement(By.id("input1"));   
  22.         /** 进入id="frame"的frame中,定位id="div1"的div和 id="input1"的输入框 */  
  23.         dr.switchTo().frame("frame");  
  24.         dr.findElement(By.id("div1"));  
  25.         dr.findElement(By.id("input1"));  
  26.         // 此时 没跳出frame,如果这时定位default content中的元素也会报错   
  27.         // dr.findElement(By.id("id1"));//error   
  28.         /** 跳出frame,进入default content;重新定位id="id1"的div */  
  29.         dr.switchTo().defaultContent();  
  30.         WebElement we = dr.findElement(By.id("id1"));  
  31.         System.out.println(we.getTagName() + "***" + we.getAttribute("id"));  
  32.     }  
  33.   
  34. }  
/*** This class is about Test_i\frame.
 * @author annie.wang  
 */
package com.annie.test;

import org.openqa.selenium.By;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.firefox.FirefoxDriver;

public class Iframe_Test {
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		WebDriver dr = new FirefoxDriver();
		String url = "C:\\Users\\Administrator\\Desktop\\frametest\\main.html";
		dr.get(url);
		/** 在default content定位id="id1"的div */
		dr.findElement(By.id("id1"));
		// 此时没有进入到id="frame"的frame 中时,以下两句会报错
		// dr.findElement(By.id("div1"));//error
		// dr.findElement(By.id("input1"));
		/** 进入id="frame"的frame中,定位id="div1"的div和 id="input1"的输入框 */
		dr.switchTo().frame("frame");
		dr.findElement(By.id("div1"));
		dr.findElement(By.id("input1"));
		// 此时 没跳出frame,如果这时定位default content中的元素也会报错
		// dr.findElement(By.id("id1"));//error
		/** 跳出frame,进入default content;重新定位id="id1"的div */
		dr.switchTo().defaultContent();
		WebElement we = dr.findElement(By.id("id1"));
		System.out.println(we.getTagName() + "***" + we.getAttribute("id"));
	}

}

结果:




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值