Selenium-WebDriver框架常用基本操作
1.基础元素定位的八种方法
WebDriver driver = new ChromeDriver();
WebElement element = new WebElement();
1.1 By.id()
element = driver.findElement(By.id)
1.2 By.name()
1.3 By.xpath()
1.3.1 路径匹配
(1)用“/”指示节点路径
如“/A/C/D” 表示节点"A"的子节点"C"的子节点"D", “/”表示根节点。
(2)用“//” 表示所有路径以"//"后指定的子路径结尾的元素
如“//E” 表示所有E元素,结果是所有三个E元素,如“//C/E”表示所有父节点为C的E元素。
(3)用“*” 表示路径的通配符
如“/A/B/C/*”表示 A元素→B元素→C元素下的所有子元素
1.3.2 位置匹配
对于每一个元素,它的各个子元素是有序的。
如:/A/B/C[1]表示A元素→B元素→C元素的第一个子元素 /A/B/C[last()]表示A元素→B元素→C元素的最后一个子元素 /A/B/C[position()>1]表示A元素→B元素→C元素之下的位置号大于1的元素
1.3.3 属性及属性值
在XPath中可以利用属性及属性值来匹配元素,要注意的是,元素的属性名前要有"@"前缀。例如:
//B[@id]表示所有具有属性id的B元素
//B[@*]表示所有具有属性的B元素
//B[not(@*)]表示所有不具有属性的B元素
//B[@id="b1"] id值为b1的B元素
1.3.4 亲属关系搭配
XML文档可归结为树型结构,因此任何一个节点都不是孤立的。通常我们把节点之间的归属关系归结为一种亲属关系,如父亲、孩子、祖先、后代、兄弟等等。在对元素进行匹配时,同样可以用到这些概念。例如:
//E/parent::* 表示所有E节点的父节点元素
//F/ancestor::* 表示所有F元素的祖先节点元素
/A/child::* 表示A的所有子元素
/A/descendant::* 表示A的所有后代元素
//F/self::* 表示所有F的自身元素
//F/ancestor-or-self::* 表示所有F元素及它的祖先节点元素
/A/C/descendant-or-self::* 表示所有A元素→C元素及它们的后代元素
/A/C/following-sibling::* 表示A元素→C元素的紧邻的后序所有兄弟节点元素
/A/C/preceding-sibling::* 表示A元素→C元素的紧邻的前面所有兄弟节点元素
/A/B/C/following::* 表示A元素→B元素→C元素的后序的所有元素
/A/C/preceding::*
表示A元素→C元素的前面的所有元素
1.3.5 条件匹配
条件匹配就是利用一些函数的运算结果的布尔值来匹配符合条件的节点。常用于条件匹配的函数有四大类:节点函数、字符串函数、数值函数、布尔函数。例如last()、position()等等
例子如下:
1./A/B/C[position()>1]表示A元素→B元素→C元素之下的位置号大于1的元素
2.
/A/B/C[last()]表示A元素→B元素→C元素的最后一个子元素
3.//B[not(@id)]表示所有不具有id属性的B元素
4. "//a[contains(@href,
'news')]")在页面中寻找href属性值中包含“news”的所有a元素
5. //a[starts-with(@href,
'http://news')]") 在页面中寻找href属性值中以“http://news”开头的所有a元素。@后面可以跟着寻找元素的任意属性名
6.其他的就不一一列举了
1.4 By.tagName()
使用tagName方法来查找元素,一般元素都是不止一个,可以结合findElements方法和type属性来精准定位。
例如:List<WebElement>
a = driver.findElements(By.tagName("a"));
1.5 By.className()
1.6 By.linkText
<a href="http://news.baidu.com" name="tj_trnews" class="mnav">新闻</a>
driver.findElement(By.linkText(“新闻”));
1.7 By.partiaLinkText()
driver.findElement(By.linkText(“新”));
1.8 By.cssSelectior()
此方法和By.xpath()类似,不熟悉规则可以直接用浏览器中的插件直接右击元素,选择Copy – Copy selector即可
2对浏览器窗口的一些操作
2.1.弹出窗口为Confirm类型
选择确认:
Alert al =
driver.switchTo().alert();
al.accept();
选择取消:
Alert al =
driver.switchTo().alert();
al.dismiss();
2.2 弹出窗口为Alert类型
Alert
al = driver.switchTo().alert();
al.accept();
2.3 放大浏览器窗口
driver.manage().window().maximize();
2.4 关闭浏览器
driver.quit();关闭整个浏览器
driver.close();关闭当前浏览器标签页
2.5 刷新/前进/后退
driver.navigate().refresh();
driver.navigate().forwari();
driver.navigate().back();
2.6 获取浏览器当前title
driver.getTitle();
2.7 获取浏览器当前url
driver.getCurrentUrl();
2.8 获取当前页面源码信息
driver.getPageSource();
2.9 其他的就不一一列举了
2.10 切换浏览器页签
String currentWindow = driver.getWindowHandle();
List<String> windows = driver.getWindowHandles();
driver.swithTo.window(windows(1));
- 其他基本操作方法后续再补充…
Selenium-WebDriver框架常用基本操作的更多相关文章
- [selenium webdriver Java]常用api
1. 获取元素文本 WebElement类的getText()方法返回元素的innerText属性.所以元素里如果有子节点一样也会被返回出来.如下所示 public class GetText { @ ...
- selenium webdriver入门
写在前面:最近在研究UI自动化测试的过程中,发现公司里通常用的是AutomanX框架,而这个框架实际上是基于selenium webdriver框架的,所以在编写测试用例时,很多语法都是直接使用sel ...
- Selenium Webdriver元素定位的八种常用方式
楼主原创,欢迎学习和交流,码字不容易,转载请注明出处,谢谢. 在使用selenium webdriver进行元素定位时,通常使用findElement或findElements方法结合By类返回的元素 ...
- Selenium WebDriver + python 自动化测试框架
目标 组内任何人都可以进行自动化测试用例的编写 完全分离测试用例和自动化测试代码,就像写手工测试用例一下,编写excel格式的测试用例,包括步骤.检查点,然后执行自动化工程,即可执行功能自动化测试用例 ...
- python+selenium自动测试之WebDriver的常用API(基础篇二)
本篇介绍一下python+selenium复杂操作的处理,基于python3.6,selenium3.141,详细资料介绍查看官方API文档,点击这里 一.常见特殊情况处理如iframe/弹窗处理 有 ...
- python selenium webdriver入门基本操作
python selenium webdriver入门基本操作 未经作者允许,禁止转载! from selenium import webdriver import time driver=webdr ...
- Selenium Webdriver元素定位的八种常用方式(转载)
转载自 https://www.cnblogs.com/qingchunjun/p/4208159.html 在使用selenium webdriver进行元素定位时,通常使用findElement或 ...
- Python3 Selenium WebDriver网页的前进、后退、刷新、最大化、获取窗口位置、设置窗口大小、获取页面title、获取网页源码、获取Url等基本操作
Python3 Selenium WebDriver网页的前进.后退.刷新.最大化.获取窗口位置.设置窗口大小.获取页面title.获取网页源码.获取Url等基本操作 通过selenium webdr ...
- selenium.webdriver.common.keys 模块中常用的变量
表11-5 selenium.webdriver.common.keys 模块中常用的变量属性 含义Keys.DOWN, Keys.UP, Keys.LEFT,Keys.RIGHT 键盘箭头键Keys ...
随机推荐
- P2801 教主的魔法(分块入门)
两个月之前听yyr学长讲的分块,感觉是个很神奇的暴力,但到现在还是懵的一匹 #include<bits/stdc++.h> using namespace std; ; int belon ...
- LogHelper 日志
public class LogHelper : Abp.Domain.Services.DomainService { public static void Debug(object message ...
- HTML 5 & checkbox & switch components
HTML 5 & checkbox & switch components <!DOCTYPE html> <html lang="zh-Hans" ...
- IFE第一天
我也不知道自己到底能坚持多少天,希望66天可以坚持下来,flag在此. 第一天的知识大概就是了解一些基本概念. Web: 基于HTTP协议,利用浏览器访问网站. HTML 大概就是告诉浏览器我有一个什 ...
- 【LUOGU???】WD与地图 整体二分 线段树合并
题目大意 有一个简单有向图.每个点有点权. 有三种操作: 修改点权 删除一条边 询问和某个点在同一个强连通分量中的点的前 \(k\) 大点权和. \(n\leq 100000,m,q\leq 2000 ...
- .Net Core实践3 配置文件
环境 .netcore2.1 / vs2017 / win10 / centos7 在.netcore项目中读取配置文件,先添加应用程序配置文件App.config.这个是类库项目的配置文件名. Sy ...
- [hosts]在hosts中屏蔽一级域名和二级域名的写法
一级域名,如baidu: 0.0.0.0 baidu.com 二级域名 如有道公开课 0.0.0.0 ke.youdao.com 不带协议名,不带www. 用127.0.0.1也可以.
- 小计:Shopee批量删除修复~附脚本
需求 昨天浪的时候,无意之间看到文职人员在一个个删除违禁商品,大概23个店铺,每个店铺500多个商品,页面是用Ajax异步加载的,每删一个就需要等几秒,粗略估计一下用时:9h左右 然后了解了下是什么情 ...
- vue-cli 项目踩坑 npm install 时出错
1.报错如下: 2.此时你执行npm run dev / npm run build 会报错如下 npm ERR! code ELIFECYCLEnpm ERR! errno 1npm ERR! v ...
- git合并常见冲突
如果一个文件在服务器上已经做了修改,然后在本地开发中又做了一些修改的时候,再发布这个文件时很容易造成代码冲突,错误如下, error: Your local changes to the follow ...