作者:Surpassme

来源:http://www.jianshu.com/p/08ee1929875f

声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢。

单选按钮通常用在需要与用户进行交互且只能选一个选项的情况。下面即是一个典型的单选按钮示例:

  1. 请选择您的性别:
  2. <input type="radio" name="gender" value="male" id="male" checked="checked">男
  3. <input type="radio" name="gender" value="female" id="female" />女<br />

选中单选按钮

通常情况下,在一个单选按钮组里面,它们的名字是一样的。所以我们使用定位的时候,不建议使用Name属性进行定位,建议使用Id、XPath和CssSelector进行定位,如下所示:

  1. driver.FindElement(By.XPath("//input[@name='gender' and @value='male']")).Click();
  2. Thread.Sleep(1000);
  3. driver.FindElement(By.Id("female")).Click();

清除单选按钮的选中状态

对于一个已经选中的单选按钮进行多次点击,是不会带来任何影响的,下面的示例代码在测试过程中依然可以正常通过。

  1. driver.FindElement(By.Id("female")).Click();
  2. driver.FindElement(By.Id("female")).Click(); //已经选中,多次点击没有任何影响

如果一个单选按钮被选中,在Selenium中清除选中状态的常用方法是点击另一个单选按钮。下面的示例使用Clear()方法清除单选按钮的选中状态将会抛出异常Invalid Element State:Element Must Be User-Editable in Order to Clear It.

  1. driver.FindElement(By.Id("female")).Click();
  2. try
  3. {
  4. driver.FindElement(By.Id("female")).Clear();
  5. }
  6. catch (Exception ex)
  7. {
  8. throw ex;
  9. }

报错截图如下所示:

下面的示例演示了既抛出了异常也按预期的目标实现了点击,示例如下:

  1. driver.FindElement(By.Id("female")).Click();
  2. try
  3. {
  4. driver.FindElement(By.Id("female")).Clear();
  5. }
  6. catch (Exception ex)
  7. {
  8. Console.WriteLine("不能清除单选状态,报错信息为:\n"+ex.ToString());
  9. }
  10. finally
  11. {
  12. driver.FindElement(By.Id("male")).Click();
  13. }

判断单选按钮状态

  1. IWebElement femaleEle = driver.FindElement(By.Id("female"));
  2. IWebElement maleEle = driver.FindElement(By.Id("male"));
  3. bool flag = femaleEle.Selected;
  4. if (flag)
  5. {
  6. maleEle.Click();
  7. Assert.IsTrue(maleEle.Selected);
  8. }
  9. else
  10. {
  11. femaleEle.Click();
  12. Assert.IsTrue(femaleEle.Selected);
  13. Assert.IsFalse(maleEle.Selected);
  14. }

通过循环点击单选按钮

在这之前我基本上仅使用方法FindElement()来查找定位元素,而在Selenium中还有另外一种方法FindElements(),示例如下:

  1. ReadOnlyCollection<IWebElement> elements = driver.FindElements(By.Name("gender"));
  2. Assert.AreEqual<int>(2,elements.Count);
  3. foreach (IWebElement item in elements)
  4. {
  5. if (item.GetAttribute("value")=="female")
  6. {
  7. item.Click();
  8. }
  9. }

与方法FindElement()不一样的是,方法FindElements()会返回能匹配到条件的集合,这对一些比较难定位的元素是非常有用的一个方法。

选中第N个单选按钮

在Name属性值相同且单选按钮也比较多的情况下,除了上面的方法循环判断来点击外,也可以通过XPath和以下方法来点击单选按钮,示例如下:

  1. driver.FindElements(By.Name("gender"))[1].Click();
  2. Assert.IsTrue(driver.FindElements(By.Name("gender"))[1].Selected);
  3. driver.FindElement(By.XPath("//input[1]")).Click();
  4. Assert.IsTrue(driver.FindElement(By.XPath("//input[1]")).Selected);

请注意里面的下标,C#下标默认是从0开始,而XPath里面下标默认是从1开始。

一些特殊的单选按钮:iCheck

针对一些默认的控件界面存在不好看的情况,一些大牛会自定义一些控件,比如下面这种单选按钮:

  1. <ul>
  2. <li>
  3. <div class="iradio_square-blue checked hover">
  4. <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"/>
  5. <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;"/>
  6. </div>
  7. <label class="hover" for="input-3"> Radio button,
  8. <span>#input-3</span>
  9. </label>
  10. <li>
  11. <li>
  12. <div class="iradio_square-blue">
  13. <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"/>
  14. <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;"/>
  15. </div>
  16. <label class="" for="input-4"> Radio button,
  17. <span>#input-4</span>
  18. </label>
  19. </li>
  20. </ul>

以下这段代码如果按之前的方法进行定位,将出错:

  1. driver.FindElement(By.Id("input-3")).Click();
  2. driver.FindElements(By.ClassName("iCheck-helper"))[0].Click();
  3. driver.FindElements(By.ClassName("iCheck-helper"))[1].Click();

正确的代码如下:

  1. public void TestRadioButton()
  2. {
  3. IWebDriver driver = new ChromeDriver();
  4. string url = "http://www.51xuediannao.com/js/jquery/icheck.html";
  5. driver.Navigate().GoToUrl(url);
  6. driver.Manage().Window.Maximize();
  7. driver.FindElement(By.Id("demolink")).Click();
  8. driver.SwitchTo().Window(driver.WindowHandles[1]);
  9. Thread.Sleep(1000);
  10. driver.SwitchTo().Frame(0);
  11. IWebElement ele = driver.FindElement(By.XPath("//div[contains(@class,'demo-list')]/ul[2]/li[1]/label"));
  12. ele.Click();
  13. }

个人理解,特别是基于UI层面的自动化测试,对象查找定位是特别重要的,需要我们结合多种方法进行。常见的IdXPathCssSelector等定位方法,有时候甚至用JavaScript知识,需要了解和掌握的知识太多,另外还需要多看看Selenium API等。在自动化这条路上还任重道远了。

[Selenium With C#基础教程] Lesson-06 单选按钮的更多相关文章

  1. [Selenium With C#基础教程] Lesson-07 复选框

    作者:Surpassme 来源:http://www.jianshu.com/p/98ede43da3c3 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢.   [作者:Surp ...

  2. [Selenium With C#基础教程] Lesson-01环境搭建

    作者:Surpassme 来源:http://www.jianshu.com/p/33b87bc00233 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 最近开始复习Sele ...

  3. [Selenium With C#基础教程] Lesson-03 超级链接

    作者:Surpassme 来源:http://www.jianshu.com/p/83809943e751 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 超级链接或链接是We ...

  4. [Selenium With C#基础教程] Lesson-02 Web元素定位

    作者:Surpassme 来源:http://www.jianshu.com/p/cfd4ed1daabd 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 使用Selenium ...

  5. [Selenium With C#基础教程] Lesson-05 文本框

    作者:Surpassme 来源:http://www.jianshu.com/p/7dca7d0d1ea3 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. 文本框在Web页面中 ...

  6. [Selenium With C#基础教程] Lesson-04 按钮

    作者:Surpassme 来源:http://www.jianshu.com/p/83d7416c4b7d 声明:本文为原创文章,如需转载请在文章页面明显位置给出原文链接,谢谢. Button通常有两 ...

  7. Selenium IDE 基础教程

    Selenium IDE 基础教程 1.下载安装     a 在火狐浏览其中搜索附件组件,查找 Selenium IDE     b 下载安装,然后重启firefox 2.界面讲解      在菜单- ...

  8. [小北De编程手记] : Lesson 06 - Selenium For C# 之 流程控制

    无论你是用哪一种自动化测试的驱动框架,当我们构建一个复杂应用程序的自动化测试的时候.都希望构建一个测试流程稳定,维护成本较低的自动化测试.但是,现实往往没有理想丰满.而这一篇,我会为大家讲解我们在使用 ...

  9. 《JavaScript基础教程(第8版)》PDF

    简介:JavaScript基础教程(第8版)循序渐进地讲述了JavaScript及相关的CSS.DOM.Ajax.jQuery等技术.书中从JavaScript语言基础开始,分别讨论了图像.框架.浏览 ...

随机推荐

  1. django No migrations to apply 问题解决

    最近在用django写项目,有的时候字段不够用,需要models增加字段,但是想回滚或者修改或者修改了属性等,例如忘了添加meta table于是操作了migrations 导致makemigrati ...

  2. ncbi API

    https://www.ncbi.nlm.nih.gov/sviewer/?db=nuccore&query_key=2&term=DYNLL2&page_size=1& ...

  3. mac 使用svn记录

    checkout  project : svn checkout svn://127.0.0.1/repository --username=username --password=password ...

  4. 深入浅出 Java Concurrency (9): 锁机制 part 4 锁释放与条件变量 (Lock.unlock And Condition)

    本小节介绍锁释放Lock.unlock(). Release/TryRelease unlock操作实际上就调用了AQS的release操作,释放持有的锁. public final boolean ...

  5. php对业务平台接口调用的封装格式

    1.封装类示例:E:\html\pim\php_mcloud_cas\util\UmcPlatform.class.php <?php class Util_UmcPlatform{ const ...

  6. vector array and normal stanard array

    array 数组的长度固定 vector 自由存储区(栈),动态长度 普通标准数组相对较不安全,不方便; array,vector对象成员函数支持数组越界检测,同时代价是效率问题: array,普通标 ...

  7. windows下使用SQLPLUS制作BAT执行SQL文件

    假如你把需要的SQL操作信息等均放入到一个SQL文件中,需要制作一个bat文件来执行这个sql文件,那么你的bat文件中,在sqlplus登录语句后的信息不能换行,换行的话则执行登录sqlplus后就 ...

  8. Nuxt.js开启SSR渲染快速入门

    第一节:nuxt.js相关概述 nuxt.js简单的说是Vue.js的通用框架,最常用的就是用来作SSR(服务器端渲染).Vue.js是开发SPA(单页应用)的,Nuxt.js这个框架,用Vue开发多 ...

  9. ansible初识三

    一.setup模块 ansible的 setup模块主要用来收集信息, 查看参数: [root@localhost ~]# ansible-doc -s setup # 查看参数,部分参数如下: fi ...

  10. Ansible 快速上手

    Ansible优点: 充分利用现有设施.使用 Ansible 无需安装服务端和客户端,只要 SSH 即可.这意味着,任何一台装有 Ansible 的机器都可以成为强大的管理端.我觉得,这种去中心化的思 ...