2012-07-24 78 views
-1

如何編寫會點擊一個網頁鏈接在規定的條件代碼:選擇元素並點擊鏈接,如果條件

腳本應該考慮每個div.table行並檢查列表元素(div.domains UL LI)包含某些字符串(somedomain.com),然後單擊div.table-row中div.actions中的鏈接a.delete鏈接。

繼承人的HTML結構:

<div class="table-row"> 
    <div class="domains"> 
    <ul> 
    <li>somedomain.com</li 
    <li>someotherdomain.com</li> 
    </ul> 
    </div> 
    <div class="actions"> 
    <ul class="menu"> 
    <li><a class="delete">Delete</a></li> 
    </div> 
</div> 

如何寫這個代碼紅寶石機械化?

我不知道如何選擇所有.table行,並通過它們循環來點擊刪除鏈接,如果條件滿足?

感謝您的幫助

+0

xpath?請參閱:http://stackoverflow.com/questions/2470202/in-xpath-how-to-select-the-element-content – Rimian 2012-07-25 00:09:52

+0

這些鏈接沒有href屬性,因此點擊它們不會做任何有意義的事情 – pguardiario 2012-07-25 05:17:18

回答

0

你需要通過元素使用JavaScript(不ROR)中循環,並檢查是否有正確的類名。沒有辦法以編程方式「點擊」鏈接,但可以使用Javascript來執行所需的操作。

<div class="table-row"> 
<div class="domains"> 
    <ul> 
    <li class="domain1">somedomain.com</li> 
    <li class="domain2">someotherdomain.com</li> 
    </ul> 
</div> 
<div class="actions"> 
<ul class="menu"> 
    <li><a class="delete">Delete</a></li> 
</div> 

至於JavaScript的,這種事情是最容易像jQuery JavaScript框架,但手動它看起來是這樣的:

<script type="text/javascript"> 
    function searchForDomains(domainName) { 
    var divs = document.getElementsByTagName('DIV'); 
    for (var i = 0; i < divs.length; i++) { 
    var div = divs[i]; 
    if (div.className == 'table-row') { 
     var tableRow = div; 
     var lis = tableRow.getElementsByTagName('LI'); 
     for (var j = 0; j < lis.length; j++) { 
     var li = lis[j]; 
     if (li.innerHTML == domainName) { 
      doDelete(tableRow); 
     } 
    } 
    } 
    } 

    function doDelete(tableRow) { 
    // do whatever it is that you'd like to see happen if the delete link was clicked. 
    } 

什麼這是循環遍歷頁面上的所有DIV,並且當它找到具有正確類的DIV時,它會遍歷該DIV中的所有LI,並且當它找到您要查找的域名,它會調用執行某個操作的函數。您可以在頁面加載或響應用戶操作(如按下按鈕)時調用此函數。