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更具代表性,实际上它是与其他可空类型兼容的,除了字符串,所以我想象的是设计。

相关文章

### 创建一个gRPC服务项目(grpc服务端)和一个 webapi项目(...
一、SiganlR 使用的协议类型 1.websocket即时通讯协议 2.Ser...
.Net 6 WebApi 项目 在Linux系统上 打包成Docker镜像,发布为...
一、 PD简介PowerDesigner 是一个集所有现代建模技术于一身的...
一、存储过程 存储过程就像数据库中运行的方法(函数) 优点:...
一、Ueditor的下载 1、百度编辑器下载地址:http://ueditor....