[Selenium With C#基础教程] Lesson-06 单选按钮
作者:Surpassme
来源:http://www.jianshu.com/p/08ee1929875f
声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢。
单选按钮通常用在需要与用户进行交互且只能选一个选项的情况。下面即是一个典型的单选按钮示例:

请选择您的性别:
<input type="radio" name="gender" value="male" id="male" checked="checked">男
<input type="radio" name="gender" value="female" id="female" />女<br />
选中单选按钮
通常情况下,在一个单选按钮组里面,它们的名字是一样的。所以我们使用定位的时候,不建议使用Name属性进行定位,建议使用Id、XPath和CssSelector进行定位,如下所示:
driver.FindElement(By.XPath("//input[@name='gender' and @value='male']")).Click();
Thread.Sleep(1000);
driver.FindElement(By.Id("female")).Click();
清除单选按钮的选中状态
对于一个已经选中的单选按钮进行多次点击,是不会带来任何影响的,下面的示例代码在测试过程中依然可以正常通过。
driver.FindElement(By.Id("female")).Click();
driver.FindElement(By.Id("female")).Click(); //已经选中,多次点击没有任何影响
如果一个单选按钮被选中,在Selenium中清除选中状态的常用方法是点击另一个单选按钮。下面的示例使用Clear()方法清除单选按钮的选中状态将会抛出异常Invalid Element State:Element Must Be User-Editable in Order to Clear It.
driver.FindElement(By.Id("female")).Click();
try
{
driver.FindElement(By.Id("female")).Clear();
}
catch (Exception ex)
{
throw ex;
}
报错截图如下所示:

下面的示例演示了既抛出了异常也按预期的目标实现了点击,示例如下:
driver.FindElement(By.Id("female")).Click();
try
{
driver.FindElement(By.Id("female")).Clear();
}
catch (Exception ex)
{
Console.WriteLine("不能清除单选状态,报错信息为:\n"+ex.ToString());
}
finally
{
driver.FindElement(By.Id("male")).Click();
}
判断单选按钮状态
IWebElement femaleEle = driver.FindElement(By.Id("female"));
IWebElement maleEle = driver.FindElement(By.Id("male"));
bool flag = femaleEle.Selected;
if (flag)
{
maleEle.Click();
Assert.IsTrue(maleEle.Selected);
}
else
{
femaleEle.Click();
Assert.IsTrue(femaleEle.Selected);
Assert.IsFalse(maleEle.Selected);
}
通过循环点击单选按钮
在这之前我基本上仅使用方法FindElement()来查找定位元素,而在Selenium中还有另外一种方法FindElements(),示例如下:
ReadOnlyCollection<IWebElement> elements = driver.FindElements(By.Name("gender"));
Assert.AreEqual<int>(2,elements.Count);
foreach (IWebElement item in elements)
{
if (item.GetAttribute("value")=="female")
{
item.Click();
}
}
与方法FindElement()不一样的是,方法FindElements()会返回能匹配到条件的集合,这对一些比较难定位的元素是非常有用的一个方法。
选中第N个单选按钮
在Name属性值相同且单选按钮也比较多的情况下,除了上面的方法循环判断来点击外,也可以通过XPath和以下方法来点击单选按钮,示例如下:
driver.FindElements(By.Name("gender"))[1].Click();
Assert.IsTrue(driver.FindElements(By.Name("gender"))[1].Selected);
driver.FindElement(By.XPath("//input[1]")).Click();
Assert.IsTrue(driver.FindElement(By.XPath("//input[1]")).Selected);
请注意里面的下标,C#下标默认是从0开始,而XPath里面下标默认是从1开始。
一些特殊的单选按钮:iCheck
针对一些默认的控件界面存在不好看的情况,一些大牛会自定义一些控件,比如下面这种单选按钮:

<ul>
<li>
<div class="iradio_square-blue checked hover">
<input id="input-3" tabindex="3" name="demo-radio" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;" type="radio"/>
<ins class="iCheck-helper" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;"/>
</div>
<label class="hover" for="input-3"> Radio button,
<span>#input-3</span>
</label>
<li>
<li>
<div class="iradio_square-blue">
<input id="input-4" tabindex="4" name="demo-radio" checked="" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;" type="radio"/>
<ins class="iCheck-helper" style="position: absolute; top: -20%; left: -20%; display: block; width: 140%; height: 140%; margin: 0px; padding: 0px; background: rgb(255, 255, 255) none repeat scroll 0% 0%; border: 0px none; opacity: 0;"/>
</div>
<label class="" for="input-4"> Radio button,
<span>#input-4</span>
</label>
</li>
</ul>
以下这段代码如果按之前的方法进行定位,将出错:
driver.FindElement(By.Id("input-3")).Click();
driver.FindElements(By.ClassName("iCheck-helper"))[0].Click();
driver.FindElements(By.ClassName("iCheck-helper"))[1].Click();
正确的代码如下:
public void TestRadioButton()
{
IWebDriver driver = new ChromeDriver();
string url = "http://www.51xuediannao.com/js/jquery/icheck.html";
driver.Navigate().GoToUrl(url);
driver.Manage().Window.Maximize();
driver.FindElement(By.Id("demolink")).Click();
driver.SwitchTo().Window(driver.WindowHandles[1]);
Thread.Sleep(1000);
driver.SwitchTo().Frame(0);
IWebElement ele = driver.FindElement(By.XPath("//div[contains(@class,'demo-list')]/ul[2]/li[1]/label"));
ele.Click();
}
个人理解,特别是基于UI层面的自动化测试,对象查找定位是特别重要的,需要我们结合多种方法进行。常见的Id、XPath、CssSelector等定位方法,有时候甚至用JavaScript知识,需要了解和掌握的知识太多,另外还需要多看看Selenium API等。在自动化这条路上还任重道远了。
[Selenium With C#基础教程] Lesson-06 单选按钮的更多相关文章
- [Selenium With C#基础教程] Lesson-07 复选框
作者:Surpassme 来源:http://www.jianshu.com/p/98ede43da3c3 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. [作者:Surp ...
- [Selenium With C#基础教程] Lesson-01环境搭建
作者:Surpassme 来源:http://www.jianshu.com/p/33b87bc00233 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 最近开始复习Sele ...
- [Selenium With C#基础教程] Lesson-03 超级链接
作者:Surpassme 来源:http://www.jianshu.com/p/83809943e751 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 超级链接或链接是We ...
- [Selenium With C#基础教程] Lesson-02 Web元素定位
作者:Surpassme 来源:http://www.jianshu.com/p/cfd4ed1daabd 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 使用Selenium ...
- [Selenium With C#基础教程] Lesson-05 文本框
作者:Surpassme 来源:http://www.jianshu.com/p/7dca7d0d1ea3 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 文本框在Web页面中 ...
- [Selenium With C#基础教程] Lesson-04 按钮
作者:Surpassme 来源:http://www.jianshu.com/p/83d7416c4b7d 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. Button通常有两 ...
- Selenium IDE 基础教程
Selenium IDE 基础教程 1.下载安装 a 在火狐浏览其中搜索附件组件,查找 Selenium IDE b 下载安装,然后重启firefox 2.界面讲解 在菜单- ...
- [小北De编程手记] : Lesson 06 - Selenium For C# 之 流程控制
无论你是用哪一种自动化测试的驱动框架,当我们构建一个复杂应用程序的自动化测试的时候.都希望构建一个测试流程稳定,维护成本较低的自动化测试.但是,现实往往没有理想丰满.而这一篇,我会为大家讲解我们在使用 ...
- 《JavaScript基础教程(第8版)》PDF
简介:JavaScript基础教程(第8版)循序渐进地讲述了JavaScript及相关的CSS.DOM.Ajax.jQuery等技术.书中从JavaScript语言基础开始,分别讨论了图像.框架.浏览 ...
随机推荐
- javaweb地图定位demo
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01//EN" "http://www.w3.org/TR/html4/stri ...
- Tkinter PanedWindow
Tkinter PanedWindow: 一个PanedWindow是一个容器部件可能包含任何数量的窗格,水平或垂直排列 一个PanedWindow是一个容器部件可能包含任何数量的窗格,水平 ...
- GeoServer之图层的新建与发布
GeoServer之图层的新建与发布 GeoServer的图层发布并不复杂,在经过: 1.创建工作区 2.添加新的数据存储 3.编写styles 后:我们就可以很简单的创建图层了. 1.在新建图层中选 ...
- FireDAC 接占线导致另一个 hstmt DataSnap
[FireDAC][Phys][ODBC][Microsoft][ODBC SQL Server Driver]连接占线导致另一个 hstmt 同样的程序,在2台win10 正常,1台win10 报连 ...
- Spring Boot实践——SpringMVC视图解析
一.注解说明 在spring-boot+spring mvc 的项目中,有些时候我们需要自己配置一些项目的设置,就会涉及到这三个,那么,他们之间有什么关系呢? 首先,@EnableWebMvc=Web ...
- Git 联机版
简介: 之前研究了 Git 单机版 ( 单兵作战 ),今天来研究一下 Git 联机版 ( 团队协作 )! GitHub 是一个开源的代码托管平台,可以分享自己的代码到该平台上,让大家参与开发或供大家使 ...
- Mysql配置文件详解 my.cof
Mysql配置文件详解 # For advice on how to change settings please see # http://dev.mysql.com/doc/refman/5.6/ ...
- 27-水池数目(dfs)
水池数目 时间限制:3000 ms | 内存限制:65535 KB 难度:4 描述 南阳理工学院校园里有一些小河和一些湖泊,现在,我们把它们通一看成水池,假设有一张我们学校的某处的地图,这个地 ...
- linux zip解压缩中文乱码
这里提供两个解决方案: 1.python处理下:https://gist.github.com/wangjiezhe/7841a350983a147b6d7e 2.java的zip4j:http:// ...
- JVM垃圾回收算法及回收器详解
引言 本文主要讲述JVM中几种常见的垃圾回收算法和相关的垃圾回收器,以及常见的和GC相关的性能调优参数. GC Roots 我们先来了解一下在Java中是如何判断一个对象的生死的,有些语言比如Pyth ...