LINQ:使用 Lambda 表达式获取 CheckBoxList 的所有选定

LINQ: Get all selected values of a CheckBoxList using a Lambda expression(LINQ:使用 Lambda 表达式获取 CheckBoxList 的所有选定值)
本文介绍了LINQ:使用 Lambda 表达式获取 CheckBoxList 的所有选定值的处理方法,对大家解决问题具有一定的参考价值,需要的朋友们下面随着小编来一起学习吧!

问题描述

考虑这样一种情况,您要检索 中所有选定复选框的值的 ListIEnumerable代码>.

Consider a scenario where you want to retrieve a List or IEnumerable of the values of all the selected checkboxes in an <asp:CheckBoxList>.

这是当前的实现:

IEnumerable<int> allChecked = (from item in chkBoxList.Items.Cast<ListItem>() 
                               where item.Selected 
                               select int.Parse(item.Value));

问题:您将如何使用 lambda 表达式或 lambda 语法改进此 LINQ 查询?

Question: How would you improve this LINQ query using a lambda expression or lambda syntax?

推荐答案

在使用 lambda 表达式 - 它们只是被您使用 C# 的查询运算符所隐藏.

You are using lambda expressions - they are just concealed by your use of C#'s query operators.

考虑一下:

IEnumerable<int> allChecked = (from item in chkBoxList.Items.Cast<ListItem>() 
                               where item.Selected 
                               select int.Parse(item.Value));

编译成这样:

IEnumerable<int> allChecked = chkBoxList.Items.Cast<ListItem>()
                              .Where(i => i.Selected)
                              .Select(i => int.Parse(i.Value));

如您所见,您已经在使用两个 lambda 表达式(它们是 WhereSelect 方法的参数),而您甚至都不知道!这个查询很好,我根本不会改变它.

As you can see you are already using two lambda expressions (they are the parameters to the Where and Select methods) and you didn't even know it! This query is fine and I wouldn't change it at all.

这篇关于LINQ:使用 Lambda 表达式获取 CheckBoxList 的所有选定值的文章就介绍到这了,希望我们推荐的答案对大家有所帮助,也希望大家多多支持编程学习网!

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

DispatcherQueue null when trying to update Ui property in ViewModel(尝试更新ViewModel中的Ui属性时DispatcherQueue为空)
Drawing over all windows on multiple monitors(在多个监视器上绘制所有窗口)
Programmatically show the desktop(以编程方式显示桌面)
c# Generic Setlt;Tgt; implementation to access objects by type(按类型访问对象的C#泛型集实现)
InvalidOperationException When using Context Injection in ASP.Net Core(在ASP.NET核心中使用上下文注入时发生InvalidOperationException)
LINQ many-to-many relationship, how to write a correct WHERE clause?(LINQ多对多关系,如何写一个正确的WHERE子句?)