共计 1085 个字符,预计需要花费 3 分钟才能阅读完成。
导读 | 这篇文章主要给大家介绍了关于如何在.Net 7 中将 Query 绑定到数组的相关资料, 文中通过示例代码介绍的非常详细, 对大家的学习或者工作具有一定的参考学习价值, 需要的朋友可以参考下 |
在 .Net 7 中,我们可以通过绑定数组的方式来接收来自查询字符串的参数。这样就不需要再使用逗号分隔的字符串来获取参数了。
代码演示
假设我们需要从 query 上接受多个 id 并返回查询的结果。例如:id=1&id=2
在 .Net 7 中,我们可以这样实现:
public ActionResult GetResults([FromQuery]int[] ids)
{// 使用 ids 数组查询结果}
这样就可以直接将 id=1&id=2 这样的查询字符串绑定到 ids 数组上。
借助 IParsable 绑定更复杂的类型
如果我们需要绑定的类型比较复杂,例如:
public ActionResult GetResults([FromQuery]MyDate[] dates)
{// 使用 dates 数组查询结果}
我们可以通过实现 IParsable
public class MyDate : IParsable
{public int Month { get; set;}
public int Day {get; set;}
public void Parse(string input)
{var parts = input.Split('-');
Month = int.Parse(parts[0]);
Day = int.Parse(parts[1]);
}
public static MyDate Parse(string s, IFormatProvider? provider)
{var date = new MyDate();
date.Parse(s);
return date;
}
public static bool TryParse(string? s, IFormatProvider? provider, out MyDate result)
{
try
{result = Parse(s, provider);
return true;
}
catch
{
result = default;
return false;
}
}
}
这样就可以通过 dates=1-1&dates=2-2 这样的查询字符串来绑定到 MyDate[] 数组上了。
参考资料
Bind arrays and string values from headers and query strings:
到此这篇关于如何在.Net 7 中将 Query 绑定到数组的文章就介绍到这了
正文完
星哥玩云-微信公众号