QTP11使用DOM XPath以及CSS识别元素对象
我们知道,像DOM,Html,CSS,XPath等对对象的识别策略广泛运用于一些开源的工具,例如:Selenium,Watir,Watir-Webdriver,以前qtp版本是不支持这些东西的,现在qtp11对这些已经支持了,下面我们就看看这些特性:
Document Object Model(DOM):这东西干嘛的 ,百度之。
像下面的这些方法能应用在qtp中:
|
方法 |
描述 |
|
getElementById |
使用已知的元素id,返回第一个页面元素 |
|
getElementsByName |
返回具有指定名称的一个JavaScript数组中的所有元素 |
|
getElementsByTagName |
返回与指定的标记名的JavaScript数组的所有元素 |
在qtp里调用JavaScript 方法:
Object.RunScript(script)
例如:
Browser("title:=百度一下,你就知道").Page("title:=百度一下,你就知道").RunScript ("alert('hello');")
Using HTML DOM Methods & Properties in QTP:
要访问HTML DOM方法,我们需要使用的文档对象,我们可以使用getElementById这个方法,用他的id来获取页面元素。例如:
Set kws=Browser("title:=百度一下,你就知道").Page("title:=百度一下,你就知道").RunScript ("document.getElementById('kw');")
kws.value ="百度一下"
Set us=Browser("title:=百度一下,你就知道").Page("title:=百度一下,你就知道").RunScript ("document.getElementById('su');")
us.click
但是我们对于一些页面没有定义id的但是定义了名称,我们就可以使用getElementsByName这个方法来解决,例如:
Set kws=Browser("title:=百度一下,你就知道").Page("title:=百度一下,你就知道").RunScript ("document.getElementsByName('wd')(0);")
kws.value ="百度一下"
而这里使用getElementsByName注意需要索引值,因为他是返回一个JavaScript数组。
如果使用getElementsByTagName,我们就不需要name或者id了。例如:
Set kws=Browser("title:=百度一下,你就知道").Page("title:=百度一下,你就知道").RunScript ("document.getElementsByTagName('input')(0);")
kws.value ="百度一下"
这里不好的地方就是,当有多个的时候,它的index属性无法直接写出并且当index改变了,脚本也要改变。
通常情况下,我们都是使用组合键来识别相应的元素对象,例如:
set wd=Browser("name:=.* - 六间房秀场.*").Page("title:=.* - 六间房秀场.*").RunScript ("document.getElementById('chatForm').getElementsByTagName('input')(2) ;")
wd.value ="testing"
与此同时,我们也可以使用元素之间的关系来识别一些元素,例如:
|
document.getElementById(‘XXX’).firstChild |
通过使用getElementById返回第一个子元素 |
|
document.getElementById(‘XXX’).lastChild |
通过使用getElementById返回最后一个子元素 |
|
document.getElementById(‘XXX’).parentNode |
通过使用getElementById返回父节点 |
|
document.getElementById(‘XXX’). nextSibling |
通过使用getElementById返回下一个兄弟元素 |
|
document.getElementById(‘XXX’). previousSibling |
通过使用getElementById返回前一个兄弟元素 |
使用XPath:
在QTP11中,XPath是另一种重要的识别元素的方式,当然它也像其它工具一样被广泛的应用于开源工具中,下面就介绍下载qtp11中改方式的特性。
XPath即为XML路径语言(XML Path Language),它是一种用来确定XML文档中某部分位置的语言。
XPath基于XML的树状结构,提供在数据结构树中找寻节点的能力。起初 XPath 的提出的初衷是将其作为一个通用的、介于XPointer与XSL间的语法模型。但是 XPath 很快的被开发者采用来当作小型查询语言。(详细的介绍看这里:http://zh.wikipedia.org/wiki/XPath)
QTP提供了两种使用XPath的方式,一种是在tools-àoptions—>Webàadvanced中;另一种就是你自己通过编程使用XPath的方法和属性。
这里主要介绍第二种:
下面就看一个采用描述性编程来使用XPath的方法的例子:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("xpath:=//input").Set "testing"
在这个例子中,我们使用的是//input,”//”在xpath中表示贪婪查询,他会变量html中所有的元素,直到找到为止。
同时如果我们知道元素的确定位置,我们也可以利用绝对路径来定位,如:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("xpath:=/html/body/div[2]/div/form/input").Set "testing"
这里比较麻烦的是,这个绝对路径,我们可以通过火狐来查看同时采用这个定位是非常快的,不过元素如果改变了,就悲催了~~~,未完待续~~~
下面来介绍,在xpath中使用元素属性来定位元素:
常用的元素属性有,ID,name,index,value,type 等,在xpath中,我们可以这样使用:
Xpath:=//element[@attribute=’ attribute value’]
例如:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("xpath:=//input[@id='kw']").set "testing"
当然,我们也可以使用多个属性来定位元素,如:
Xpath:=//element[@attribute=’ attribute value’ and @attribute=’ attribute value’ ]
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("xpath:=//input[@id='kw' and @type='text' ] ").set "testing"
在一些使用AJAX构建的网站,通常他们的元素属性是动态的,例如ids,name,他们随着网页动态加载变化而变化,此时我们可以使用部分匹配的原则来定位这些元素。
在xpath中,提供了一些常见的函数,例如:cotains(),start-with(),end-with(),语法如下:
//element[start-with(@attribute,’attribute partial value’)]
// element[end-with(@attribute,’attribute partial value’)]
//element[cotains(@attribute,’attribute partial value’)]
例如下面的例子:
<div id='login_area'>
<input type='text' id='text_1'>
</div>
我们可以这样定位元素:
Browser("name:=XXX").Page("title:=XXX").WebEdit("xpath:=//div[@id=' login_area '/input[start-with(@id,’text_’)]' ] ").set "testing"
同理,其它方法也是这样用。
在这里有一种方法,直接使用text()来定位元素,这个是很方便的。语法如下:
//element[text()='inner text']
例如:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").link("xpath:=//a[text()='注册']").Click
当然我们也可以结合contains(),start-with()来使用。
语法如下:
//element[contains(text(),’inner text’)]
例如:
ss=Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").link("xpath:=//a[contains(text(),'注')]").GetROProperty("name")
msgbox ss ‘ss=注册
在qtp11中还介绍了关于xpath轴的知识,这部分没找到相关例子,就不介绍了,感兴趣的去看下w3school上关于xpath轴的介绍。
CSS在QTP11中使用:
QTP11中也增加了CSS来识别页面对象属性,关于css的介绍以及使用可以看w3school。
在qtp11中使用css的语法如下:
Css:=Element.class_attribute
例如:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("css:=input.s_ipt ").set "testing"
在dom,xpath中均能使用id,在css中也可以使用id。在css中使用id的语法如下:
Css:=element#id
例如:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("css:=input#kw ").set "testing"
当然,在css中我们也可以使用元素的属性来识别页面对象,其语法如下:
Css:=element[attribute=value]
例如:
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").WebEdit("css:=input[name=wd] ").set "testing"
另外,css中也提供了类似xpath中的部分识别属性的方法,具体方法如下:
|
Operator |
Description |
|
^=attribute_value |
找到以给定的属性值的开始的元素,这个和xpath中的 starts-with()函数相似。 |
|
*= attribute_value |
找到包含给定属性值的元素. 这个和xpath中的 contains()函数相似。 |
|
$= attribute_value |
找到以给定的属性值的结束的元素. 这个和xpath中的 ends-with()函数相似。 |
例如:
<div id='login_area'>
<input type='text' name='text_1'>
</div>
Browser(title:=XXX).Page(title:=xxx).WebEdit(“css:=div#login_area input[name^=’text_’]”).set “testing”
或者
Browser(title:=XXX).Page(title:=xxx).WebEdit(“css:=div#login_area input[name*=’text_’]”).set “testing”
在css中,也可以使用text()来定位,具体语法如下:
Css:=element:contains(‘text’)
Browser("name:=百度一下,你就知道").Page("title:=百度一下,你就知道").link("css:=a:contains('注册')").Click
QTP11使用DOM XPath以及CSS识别元素对象的更多相关文章
- Selenium自动化中DOM,XPATH,CSS定位Web页面对象的优劣性分析
加速IE浏览器自动化执行效率:Selenium自动化中DOM,XPATH,CSS定位Web页面对象的优劣性分析 1.技术背景 在Web应用中,用户通过键盘在输入框中输入值和鼠标点击按钮,链 ...
- 【WEB自动化】【第一节】【Xpath和CSS元素定位】
目前自动化测试开始投入WEB测试,使用RF及其selenium库,模拟对WEB页面进行操作,此过程中首先面对的问题就是对WEB页面元素的定位,几乎所有的关键字都需要传入特定的WEB页面元素,因此掌握常 ...
- UI自动化之元素定位(xpath、css)
很早之前就已经写过自动化了,不过点着功能久了就会容易忘记元素定位,尤其是xpath和css定位,所以就花点时间做下总结收集. xpath有两种定位: 一.绝对路径(不推荐使用,除非已经使用了所有方式仍 ...
- css选择器用法,使用css定位元素,css和xpath元素定位的区别
css定位元素 1.什么是css? CSS(Cascading Style Sheets)层叠样式表,是一种语言,用来描述html或者xml的显示样式.在css语言中有css选择器,在selenium ...
- 黄聪:HtmlAgilityPack中SelectSingleNode的XPath和CSS选择器
XPath和CSS选择器 原文:http://ejohn.org/blog/xpath-css-selectors 最近,我做了很多工作来实现一个同时支持XPath和CSS 3的解析器,令我惊讶的是: ...
- HTML DOM 元素对象
HTML DOM 元素对象 HTML DOM 节点 在 HTML DOM (Document Object Model) 中, 每个东西都是 节点 : 文档本身就是一个文档对象 所有 HTML 元素都 ...
- CSS隐藏元素的几种方法
使用CSS隐藏元素的方法很多,在这里简单总结一下: 1.display:none display:none 应该是最常用的一种隐藏元素的方法,使用该方法隐藏的元素脱离文档流不占据空间,不会被浏览器解析 ...
- JavaScript DOM编程基础精华01(DOM入门,DOM模型和获取页面元素,事件,window对象的方法)
DOM入门 DOM就是Html页面的模型,将每个标签都做为一个对象,JavaScript通过调用DOM中的属性.方法就可以对网页中的文本框.层等元素进行编程控制.比如通过操作文本框的DOM对象,就可以 ...
- DOM元素对象的属性和方法(1)
一.accessKey() 作用:获取元素焦点快捷键:设置快捷键后,使用Alt+快捷键,让元素快速获得焦点, <!DOCTYPE html> <html> <head&g ...
随机推荐
- CentOS 7(64位) 下Docker的安装
系统要求是64位,内核版本至少3.10. 首先添加yum软件源: 之后更新yum软件源缓存,并安装docker-engine 查看docker 版本: Cannot connect to the Do ...
- 字符在内存中最终的表示形式是什么?是某种字符编码还是码位(Code Point)?
字符在内存中最终的表示形式是什么?是某种字符编码还是码位(Code Point)? 根据我的了解,编码中有三个核心概念:1. 字符集(Character Set),可以说是一个抽象概念,字符的合集2. ...
- numpy中的matrix与array的区别
Numpy matrices必须是2维的,但是 numpy arrays (ndarrays) 可以是多维的(1D,2D,3D····ND). Matrix是Array的一个小的分支,包含于Array ...
- 华丽导航CSS下拉菜单特效
华丽导航CSS下拉菜单特效,华丽导航,导航特效,CSS,下拉菜单,华丽特效. 代码地址:http://www.huiyi8.com/sc/26811.html 风景图片网:http://www.hui ...
- release与debug的区别
http://www.cnblogs.com/JemBai/archive/2009/01/13/1374805.html
- CLR事件与路由事件在XAML代码中应用时的区别
<Window x:Class="Demo_window.Window2"xmlns="http://schemas.microsoft.com/winfx/200 ...
- C++(零)— 提高程序运行效率
1.尽量减少值传递,多用引用来传递参数. 2.++i和i++引申出的效率问题,使用++i. 3.避免过大的循环,由计算机的硬件决定的. 4.局部变量VS静态变量,尽量使用局部变量. 5.减少除法运算的 ...
- HTML DOM scrollTo()方法
一. 作用 scrollTo()方法可把内容滚动到指定的坐标 二. 语法 scrollTo(x, y) 其中参数x为要在窗口文档显示区左上角显示的文档的x坐标, y为要在窗口文档显示区左上角显示的 ...
- 1001 字符串“水”题(二进制,map,哈希)
1001: 字符串“水”题 时间限制: 1 Sec 内存限制: 128 MB提交: 210 解决: 39[提交][状态][讨论版] 题目描述 给出一个长度为 n 的字符串(1<=n<= ...
- 搭建Rsync服务器
部署Rsync服务器需要创建至少 一个配置文件,默认在系统中并不存在Rsync配置文件,对于服务器而言,配置文件创建完成后,使用守护进程模式启动rsync程序即可. 使用Centos 系统安装 部署R ...