3

下面的代码按预期工作,但我希望将下面的代码转换为使用 Linq?有什么建议么?

       string[] selections = "Men,Women,Boys".Split(',');           

        int _chkboxId = 0;  
        int _chkboxTextId = 1;
        try
        {
            string id = "lstchk_" + _chkboxId;
            while (!driver.FindElement(By.Id(id)).Equals(null))
            {
                string checkboxId = String.Format("lstchk{0}", _chkboxTextId);
                string checkboxName = driver.FindElement(By.Id(checkboxId)).Text;

                foreach (string match in selections)
                {
                    if (checkboxName == match.Trim())
                    {
                        //matched... do more work here...
                    }
                }
           }
4

4 回答 4

5
foreach (string match in selections.Where(match => checkboxName == match.Trim()))
{
    //matched... do more work here...
}
于 2012-09-25T02:08:38.643 回答
1
switch(checkboxName) {
    case "Men":
    case "Women":
    case "Boys":
        // do more work here
    default:
        // no match, bail
}

有时,编写代码的方式不同。

于 2012-09-25T02:08:40.550 回答
1

如果您的selections列表仅包含不同的值,则可以使用

if(selections.Any(match=>match.Trim().Equals(checkboxName)))
{
    //Do work
}

而不是你的循环。如果您的列表可能包含不明确的值,则相同,但每个工作应该只完成一次checkboxName

于 2012-09-25T02:28:32.310 回答
0

您如何将这个简单的 foreach 转换为 linq 语句?

    public List<string> GetItems()
        {
        var items = new List<string>();

        foreach (Ranorex.ListItem item in ranorexComboBox.Items)
            {
            items.Add(item.Text);
            }

        return items;
        }
于 2013-10-23T12:21:21.150 回答