辅助工具:

chrome浏览器,F12打开控制台;

Firefox浏览器,F12打开控制台;

或者选中要定位的元素右键

安装firefox扩展firebug和firepath;

安装之后F12可调用firebug;

firepath内嵌在firebug中;

选中要定位的页面元素,右键可以获得该元素的xpath和css路径,方便使用xpaht和css方式定位元素,在firepath中可以自己输入xpath表达式和css表达式来定位元素。

1.通过ID定位

public static By id(String id)
Parameters:
id - The value of the "id" attribute to search for
Returns:
a By which locates elements by the value of the "id" attribute.

之前例子中用到的:

WebElement searchButton = driver.findElement(By.id("stb"));

就可以获取到该元素.

 

2.通过name定位

public static By name(String name)
Parameters:
name - The value of the "name" attribute to search for
Returns:
a By which locates elements by the value of the "name" attribute.

之前例子中用到的:

WebElement searchInput = driver.findElement(By.name("query"));

就可以获取到该元素.

 

3.通过xpath定位

public static By xpath(String xpathExpression)
Parameters:
xpathExpression - The xpath to use
Returns:
a By which locates elements via XPath

通过firebug右键要定位的元素,已百度搜索button为例:

<input id="search-submit" class="btn-engine" type="submit" value="搜 索"/>

得到的xpath:.//*[@id='search-submit']

可以写成:

WebElement element = driver.findElement(By.xpath("//*[@id='search-submit']"))

 

4.通过cssSelector定位

public static By cssSelector(String selector)
Finds elements via the driver's underlying W3 Selector engine. If the browser does not implement the Selector API, a best effort is made to emulate the API. In this case, we strive for at least CSS2 support, but offer no guarantees.
Parameters:
selector - css expression
Returns:
a By which locates elements by CSS.

通过firebug右键要定位的元素

 

5.通过classname定位

public static By className(String className)
Finds elements based on the value of the "class" attribute. If an element has many classes then this will match against each of them. For example if the value is "one two onone", then the following "className"s will match: "one" and "two"
Parameters:
className - The value of the "class" attribute to search for
Returns:
a By which locates elements by the value of the "class" attribute.

<input id="search-submit" class="btn-engine" type="submit" value="搜 索"/>

使用classname定位的方式就为:By.className("btn-engine")

WebElement element = driver.findElement(By.className("btn-engine"));

 

6.通过linktext定位

public static By linkText(String linkText)Parameters:

linkText - The exact text to match against

Returns:

a By which locates A elements by the exact text it displays
<a class="mnav" name="tj_trnuomi" href="http://www.nuomi.com/?cid=002540">糯米</a>

使用linktext定位的方式就为:

WebElement element = driver.findElement(By.linkText("糯米"));

 

7.通过partialLinkText定位

public static By partialLinkText(String linkText)
Parameters:
linkText - The text to match against
Returns:
a By which locates A elements that contain the given link text

类似linktext的方法,通过给出的链接文本去定位,这个链接文本只要包含在整个文本中即可,可理解为模糊匹配。

 

8.通过jQuery来定位元素

在使用selenium调用jQuery查找元素之前你需要确认你要测试的页面时候使用了jQuery, 如果使用了jQuery则直接使用find方法查找元素;如果你的测试页面没有使用到jQuery,则需要对当前页面注入jQuery库。

打开控制台输入jQuery如果返回function(e, t),则说明该页面引用了jQuery,如果报错则说明没有引用jQuery。

以百度首页上的菜单为例子:

WebDriver driver = new FirefoxDriver();
driver.mange().window().maximize();
JavascriptExecutor jsExecutor = (JavascriptExecutor)driver;
driver.get("https://www.baidu.com");
List<WebElement> webElements = jsExecutor.exe cuteScript("return jQuery.find('a.mnav')");
Assert.assertEquals(webElements.size(),6);
Assert.assertEquals(webElements.get(2).getText(), "hao123");

上诉代码使用了jQuery的find方法来查找元素。找到符合"a.mnav" 的元素,然后通过JavascriptExecutor执行jQuery命令。你也可以通过firefox浏览器的控制台输入jQuery.find('a.mnav')或者$.find('a.mnav')按下回车键之后就可以返回你要查找的元素。

未加载jQuery库页面定位:

对未使用jQuery的页面,可以再加载页面的时候对这个页面注入jQuery的支持库。所以在打开页面的时候先要判断该页面是否使用的jQuery,如果没有就执行一段注入jQuery的代码,然后在使用jQuery的find方法即可。

以一个没有加载jQuery的网站http://www.2345.com/为例,通过控制台依次输入一下js可以达到注入的目的:

var headID = document.getElementsByTagName("head")[0];
var newScript = document.createElement('script');
newScript.type = 'text/Javascript';
newScript.src = "http://code.jquery.com/jquery-2.1.4.min.js";
headID.appendChild(newScript);

返回:<script type="text/Javascript" src="http://code.jquery.com/jquery-2.1.4.min.js">这段代码就证明已经注入成功,为了确保注入成功,再次在控制台输入界面输入jQuery,返回function(a, b)就说明注入成功。

在控制台输入命令:"$find('input.sch_btn')"来查找到这个“搜索一下”按钮

完整代码如下:

import java.util.List;
import org.openqa.selenium.JavascriptExecutor;
import org.openqa.selenium.WebDriver;
import org.openqa.selenium.WebDriverException;
import org.openqa.selenium.WebElement;
import org.openqa.selenium.firefox.FirefoxDriver;
import org.testng.Assert;
public class TestNotLoadJquery {
public static void main(String[] args) {
Webdriver driver = new FirefoxDriver();
driver.manage().window().maximize();
JavascriptExecutor jsExecutor = (JavascriptExecutor)driver;
driver.get("http://www.2345.com/");
if(!jQueryLoaded(jsExecutor)) {
//如果检测到没有jQuery库就执行注入操作
inJectquery(jsExecutor);
}
//找到搜索一下按钮元素
List<WebElement> searchButoon = (List<WebElement>) jsExecutor.exe cuteScript("return jQuery.find('input.sch_btn')");
//验证按钮的文本
Assert.assertEquals(searchButton.get(0).getAttribute("value"), "搜索一下")
driver.quit();
} /**注入jQuery支持**/
public static void inJectquery(JavascriptExecutor jsExecutor){ jsExecutor.executeScript("var headID = document.getElementsByTagName(\"head\")[0];"
+ "var newScript = document.createElement('script');"
+ "newScript.type = 'text/Javascript';"
+ "newScript.src=\"http://code.jquery.com/jquery-2.1.4.min.js\";"
+ "headID.appendChild(newScript);"); } /**判断当前页面是否使用了jQuery**/
public static Boolean jQueryLoaded(JavascriptExecutor jsExecutor) { Boolean laoded = true; try{
loaded = (Boolean) jsExecutor.executeScript("return jQuery()! = null");
}catch(WebDriverException e){
loaded = false;
}
return loaded;
}
}

Selenium2(java)定位页面元素 二的更多相关文章

  1. Java+selenium之WebDriver定位页面元素(二)

    Selenium-Webdriver 提供了强大的元素定位方法,支持以下三种方法: 单个对象的定位方法,多个对象的定位方法和层级定位 1. 定位单个元素 // 对于元素的属性包含 id 的情况适用,推 ...

  2. selenium第三课(selenium八种定位页面元素方法)

    selenium webdriver进行元素定位时,通过seleniumAPI官方介绍,获取页面元素的方式一共有以下八种方式,现按照常用→不常用的顺序分别介绍一下. 官方api地址:https://s ...

  3. 定位页面元素之xpath详解以及定位不到测试元素的常见问题

    一.定位元素的方法 id:首选的识别属性,W3C标准推荐为页面每一个元素设置一个独一无二的ID属性, 如果没有且很难找到唯一属性,解决方法:(1)找开发把id或者name加上.如果不行,解决思路可以是 ...

  4. selenium webdriver学习(四)------------定位页面元素(转)

    selenium webdriver学习(四)------------定位页面元素 博客分类: Selenium-webdriver seleniumwebdriver定位页面元素findElemen ...

  5. selenium定位页面元素的一件趣事

    PS:本博客selenium分类不会记载selenium打开浏览器,定位元素,操作页面元素,切换到iframe,处理alter.confirm和prompt对话框这些在网上随处可见的信息:本博客此分类 ...

  6. 使用CSS选择器定位页面元素

    摘录:http://blog.csdn.net/defectfinder/article/details/51734690 CSS选择器也是一个非常好用的定位元素的方法,甚至比Xpath强大.在自动化 ...

  7. Selenium 定位页面元素 以及总结页面常见的元素 以及总结用户常见的操作

    1. Selenium常见的定位页面元素 2.页面常见的元素 3. 用户常见的操作 1. Selenium常见的定位页面元素 driver.findElement(By.id());driver.fi ...

  8. webdriver定位页面元素时使用set_page_load_time()和JavaScript停止页面加载

    webdriver定位页面元素时使用set_page_load_time()和JavaScript停止页面加载 原文:https://my.oschina.net/u/2344787/blog/400 ...

  9. 关于appium操作真机打开app之后无法定位页面元素的问题的解决办法

    appium操作真机打开app后无法定位页面元素:例如微信或者支付宝支付时,手机的安全控件会对支付环境进行保护,会断掉当前appium与真机的链接,导致连接失败,无法定位到页面元素,在做ui自动化之前 ...

随机推荐

  1. 2016大连网络赛 Different GCD Subarray Query

    Different GCD Subarray Query Time Limit: 6000/3000 MS (Java/Others)    Memory Limit: 65536/65536 K ( ...

  2. Permission denied: user=xxj, access=WRITE, inode="user":hadoop:supergroup:rwxr-xr-x

    在windows中运行eclipse时报错Permission denied: user=xxj, access=WRITE, inode="user":hadoop:superg ...

  3. sql server 2008 把远程的数据库的数据转移到本地数据数据库里

    如题:把远程的数据库对应表里的数据转移到本地数据数据库的对应表里 比如把192.168.188.160的DB的A表的数据转移到本地的DB的A表里 第一步:连接远程服务器前准备 exec sp_addl ...

  4. android数据库sqlite增加删改查

    http://hi-beijing.iteye.com/blog/1322040 http://www.cnblogs.com/wenjiang/archive/2013/05/28/3100860. ...

  5. L11,one good turn deserves another

    one good turn deserves another 礼尚往来 gets a good salary 有一份很好的薪水 never pays it back 从不归还 deserve  应得的 ...

  6. Android学习笔记之Intent(1)

    1.Intent指定启动目标组件 2.Intentfilter描述基本组件所在地址 3.其他包引入资源文件时记得引入R所在的包 package com.jikexueyuan.intent; impo ...

  7. 丑数 LeeTCode

    题目链接:http://www.lintcode.com/zh-cn/problem/ugly-number-ii/ 题目描述:设计一个算法,找出只含素因子2,3,5 的第 n 大的数.符合条件的数如 ...

  8. ios开发证书,描述文件,bundle ID的关系

    苹果为了控制应用的开发与发布流程,制定了一套非常复杂的机制.这里面的关键词有:个人开发者账号,企业开发者账号,bundle ID,开发证书,发布证书(又叫"生产证书"),开发描述文 ...

  9. CentOS 6.4 x64 安装 配置 Redmine 2.4.1

    Redmine 安装配置 1. 安装Redmine 所需的依赖 首先安装 yaml wget http://pyyaml.org/download/libyaml/yaml-0.1.4.tar.gz ...

  10. Shell条件与测试

    分类参考 文件状态测试 -b filename 当filename 存在并且是块文件时返回真(返回0) -c filename 当filename 存在并且是字符文件时返回真 -d pathname ...