使用“包含”来匹配 lambda 表达式中的部分字符串
本文关键字:表达式 字符串 lambda 包含 使用 | 更新日期: 2023-09-27 17:56:54
我有一个MVC页面,其中我有三个不同的"输入"元素,都是同一个类,使用jQuery自动完成。 在任何一个上,我在控制器中执行此操作:
[HttpGet]
public ActionResult GetAllItemsEdit(string data, string source)
{
List<TextValuePair> items = InventoryControlRepository.GetAllItemsTVP();
var result1 = items.Where(item => item.Text.Contains(data.ToUpper())).ToList();
return Json(result1, JsonRequestBehavior.AllowGet);
}
这些项目包含以下内容:
TextValuePair tvp = new TextValuePair();
tvp.Text = item.ItemNumber + " - " + item.ItemDescription + " - SN: " + item.SerialNumber;
tvp.Value = item.ItemNumber;
list.Add(tvp);
因此,TVP Text
部分中的文本必须根据源输入字段进行匹配。 知道怎么做吗? 我需要以某种方式拆分item.Text
字段,并检查本质上的三列数据之一以匹配页面的输入。
多亏了皮特的回答,我才能够完成它。 我必须向模型添加一个字段,本质上是一个搜索字段,其中包含我想要的文本字段的值。
[HttpGet]
public ActionResult GetAllItemsEdit(string data, string source)
{
IEnumerable<ItemModel> models = InventoryControlRepository.GetAllItems();
switch (source)
{
case "txtFindSerial":
models = models.Where(x => x.SerialNumber.IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1);
break;
case "txtFindItem":
models = models.Where(x => x.ItemNumber.IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1);
break;
case "txtFindDescription":
models = models.Where(x => x.ItemDescription.IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1);
break;
}
var result1 = models.Select(item => new TextValuePair() { Text = item.SearchField, Value = item.ItemNumber }).ToList();
return Json(result1, JsonRequestBehavior.AllowGet);
}
我会搜索您的初始项目(在您进入TextValuePair
列表之前),然后您可以执行以下操作
IEnumerable<Item> items = originalItemsList;
switch (source)
{
case "1": // or whatever this should be
items = items.Where(x => x.ItemNumber.IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1);
break;
case "2": // or whatever this should be
items = items.Where(x => x.ItemDescription.IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1);
break;
case "3": // or whatever this should be
items = items.Where(x => x.SerialNumber.IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1);
break;
}
var result1 = items.Select(item => new TextValuePair() { text = item.Text, Value = item.ItemNumber }).ToList();
return Json(result1, JsonRequestBehavior.AllowGet);
如果您不能使用初始对象,那么我可能会这样做
var result1 = items.Where(item => TextMatches(item.Text, data, source)).ToList();
然后有一个方法:
private static bool TextMatches(string text, string data, string source)
{
// you may want to chose a better delimiter if your text description contains a " - "
string[] textParts = text.Split(new string[] { " - " }, StringSplitOptions.None);
switch (source)
{
case "1": // or whatever this should be
return textParts[0].IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1;
case "2": // or whatever this should be
return textParts[1].IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1;
case "3": // or whatever this should be
return textParts[2].IndexOf(data, StringComparison.InvariantCultureIgnoreCase) > -1;
}
return false;
}