微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

asp.net-mvc – ASP.NET MVC 2中的空查询字符串参数的模型绑定

现在,行为 described here现在是ASP.NET MVC 2的认值(至少对于预览1)。

当模型绑定一个querystring这样:

?Foo=&Bar=cat

发生以下绑定(假设您绑定到具有’Foo’和’Bar’字符串属性的模型)

ASP.NET MVC 1

model.Foo = "";
 model.Bar = "cat":

ASP.NET MVC 2(预览1到RC)

model.Foo = null;
 model.Bar = "cat":

想要给任何正在玩V2的人一个头脑,因为在’gu-notes‘没有提到。如果知道的任何人可以评论这是否是最终的实现还是可配置的功能,那么也好奇?我很好,但只是希望他们不要重新回到旧的方式!可配置会更好。

编辑:从这一点学习的教训是您正在开发的任何版本,而不是编写Foo.Length == 0的代码来测试一个空字符串或Foo.Length> 3检查最小长度。使用string.IsNullOrEmpty(Foo)和/或首先检查null。

更新:这个问题引发了我对他们为什么实际做出这个改变的好奇心。我认为我在研究残疾人控制时绊倒了答案。 W3 HTML规范定义了“successful control”,如下所示:

A successful control is “valid” for
submission. Every successful control
has its control name paired with its
current value as part of the submitted
form data set. A successful control
must be defined within a FORM element
and must have a control name.

换句话说,一个成功的控制是将它作为一个查询字符串参数返回到服务器。现在,如果控件没有有效的值,那么根据规范:

If a control doesn’t have a 07003
when the form is submitted,user
agents are not required to treat it as
a successful control.

(在这里用’不需要…’)发现’开放解释’语言

所以我想通过发送一个null而不是一个空字符串来减少浏览器不兼容的地方,某些浏览器可能会发送Foo =& Bar =,而其他人甚至可能不会发送该查询字符串参数。通过总是解释Foo =好像Foo不是在所有的力量你更防守。

我认为至少在正确的轨道上,为什么在这里 – 至少在一定程度上与“成功的控制”的概念有关。

http://www.w3.org/TR/html401/interact/forms.html#h-17.13.2

解决方法

Null更具代表性,实际上它是与其他可空类型兼容的,除了字符串,所以我想象的是设计。

原文地址:https://www.jb51.cc/aspnet/252207.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐