0

现在,当我运行它时,它会每 2 秒点击一次相同的按钮。我试图弄清楚如何继续使用下一个 ID,而不是继续执行它找到的第一个 ID,然后再中断。这是我的代码:

private void button2_Click(object sender, EventArgs e)
{
    timer1.Start();
}

private void timer1_Tick(object sender, EventArgs e)
{
    HtmlDocument doc = webBrowser1.Document;
    HtmlElementCollection links = doc.GetElementsByTagName("a");

    foreach (HtmlElement link in links)
    {
        if (link.GetAttribute("id").Contains("user"))
        {
            link.InvokeMember("click");
            break;
        }
    }
}
4

2 回答 2

0

一种选择是添加一个列表。
在单击按钮之前,请检查其名称是否在列表中。如果是这样,请不要点击。每次单击按钮时,将其名称添加到列表中。

于 2012-06-14T01:49:46.787 回答
0

将您的代码更改为此...

//HtmlElementCollection links = null;
List<HtmlElement> links = null;

private void button2_Click(object sender, EventArgs e)
{
    // This way you only get the links once.
    //links = webBrowser1.Document.GetElementsByTagName("a");
    links = new List<HtmlElement>(
        webBrowser1.Document.GetElementsByTagName("a")
        .OfType<HtmlElement>());

    timer1.Start();
}

private void timer1_Tick(object sender, EventArgs e)
{
    HtmlElement linkToClick = null;

    foreach (HtmlElement link in links)
    {
        if (link.GetAttribute("id").Contains("user"))
        {
            linkToClick = link;
            break;
        }
    }

    // did I find a link?
    if (linkToClick != null)
    {
        // Remove it from the list so you don't click it again.
        links.Remove(linkToClick);

        link.InvokeMember("click");
    }
    else
    {
        // Stop the timer since there are no more items.
        timer1.Stop();
    }
}

顺便说一句,我不知道 HtmlElementCollection 是否有“删除”方法......如果没有,只需使用通用 List<> 或 ArrayList 等。

于 2012-06-14T01:53:20.950 回答