2012-03-15 91 views
0

我在看的场景是我们有一个包含多个列的表格。其中一列有名称,另一列有下拉列表。我需要操纵包含特定名称的行的下拉菜单。我查看了源输出,并尝试获取元素的祖父(表格行),以便我可以搜索列表。但是,当我使用父对象时,没有这种搜索功能。找到WatiN父母的兄弟元素的孩子

似乎在自动化/测试网站上会有很多这种场景,但是我搜索了几个小时后还没有找到任何东西。任何帮助,将不胜感激。

编辑:有问题的应用程序是一个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> 
+0

您能否提供您正在搜索的HTML样本? – MotoSV 2012-03-15 21:43:16

+0

编辑帖子添加HTML样本。 – iAmMe 2012-03-16 20:26:21

回答

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(); 
       } 
      } 
     } 
    } 

希望这可以为别人节省一点时间和精力。另外,我很想看看有人有更好的解决方案。

相关问题