使用WatiN查找父级兄弟元素的子元素

时间:2012-03-15 20:50:37

标签: c# search watin siblings

我正在看的场景是我们有一个包含多列的表。其中一列有名称,另一列有下拉列表。我需要操作包含特定名称的行的下拉列表。我查看了源输出,并尝试获取元素的祖父(表行),以便我可以搜索列表。但是,当我使用父对象时,没有这样的搜索功能。

似乎在自动化/测试网站时会出现很多此类情况,但搜索几个小时后我找不到任何内容。任何帮助将不胜感激。

编辑:有问题的应用程序是一个ASP.NET,输出HTML充其量只是一样。但是,这里是一个清理的示例,说明搜索的HTML是什么样的:

<table class="myGrid" cellspacing="0" cellpadding="3" rules="all" border="1" id="ctl00_content_MyRpt_ctl01_MyGrid" style="border-collapse:collapse;">
  <tr align="left" style="color:Black;background-color:#DFDBDB;">
    <th scope="col">Name</th><th scope="col">Unit</th><th scope="col">Status</th><th scope="col">Action</th>
  </tr>
  <tr>
    <td>
      <span id="ctl00_content_MyRpt_ctl01_MyGrid_ctl02_Name">JOHN DOE</span>
    </td>
    <td>
      <span id="ctl00_content_MyRpt_ctl01_MyGrid_ctl02_UnitType">Region</span>&nbsp;
      <span id="ctl00_content_MyRpt_ctl01_MyGrid_ctl02_UnitNum">1</span> 
    </td>
    <td>
      <span id="ctl00_content_MyRpt_ctl01_MyGrid_ctl02_Status">Complete</span>                                   
    </td>
    <td class="dropdown">                                                          
      <select name="ctl00$content$MyRpt$ctl01$MyGrid$ctl02$ActionDropDown" onchange="javascript:setTimeout(&#39;__doPostBack(\&#39;ctl00$content$MyRpt$ctl01$MyGrid$ctl02$ActionDropDown\&#39;,\&#39;\&#39;)&#39;, 0)" id="ctl00_content_MyRpt_ctl01_MyGrid_ctl02_ActionDropDown" class="dropdown">
        <option value="123456">I want to...</option>
        <option value="Details.aspx">View Details</option>
        <option value="Summary.aspx">View Summary</option>
        <option value="DirectReports.aspx">View Direct Reports</option>
      </select>
    </td>
  </tr>
  <tr>
    ...
  </tr>
</table>

1 个答案:

答案 0 :(得分:0)

我找到了一种方法来做我想做的事。它可能不是最好或最优雅的解决方案,但它有效(它不是生产代码)。

    private void btnStart_Click(object sender, EventArgs e)
    {
        using (var browser = new IE("http://godev/review"))
        {
            browser.Link(Find.ByText("My Direct Reports")).Click();
            TableRow tr = browser.Span(Find.ByText("JOHN DOE")).Parent.Parent as TableRow;
            SelectList objSL = null;
            if (tr.Exists)
            {
                foreach (var td in tr.TableCells)
                {
                    objSL = td.ChildOfType<SelectList>(Find.Any) as SelectList;
                    if (objSL.Exists) break;
                }
                if (objSL != null && objSL.Exists)
                {
                    Option o = objSL.Option(Find.ByText("View Direct Reports"));
                    if (o.Exists) o.Select();
                }
            }
        }
    }

希望这能节省一些时间和精力。此外,我很想知道是否有人有更好的解决方案。