ASP.NET MVC中默认Model Binder绑定Action参数为List、Dictionary等集合的实例
2024-10-18 22:37:44
在实际的ASP.NET mvc项目开发中,有时会遇到一个参数是一个List、Dictionary等集合类型的情况,默认的情况ASP.NET MVC框架是怎么为我们绑定ASP.NET MVC的Action参数的。
有这样的一个Model类Person将作为Action的参数
Model,Person.cs:
- public class Person
- {
- public string FirstName { get; set; }
- public string LastName { get; set; }
- }
一、ASP.NET MVC中的Model绑定List集合方法
1、HomeController的有一Action为Add:
- public ActionResult Add()
- {
- return View();
- }
- [HttpPost]
- public ActionResult Add(List<Person> persons, List<string> movies)
- {
- return View();
- }
2、视图,Add.cshtml:
- @model WebApplication1.Models.Person
- @{
- ViewBag.Title = "Add";
- }
- <h2>Add</h2>
- @using (Html.BeginForm())
- {
- <h4>First Person</h4>
- @:FirstName:@Html.TextBox("[0].FirstName")
- @:LastName:@Html.TextBox("[0].LastName")
- <h4>Second Person</h4>
- @:FirstName:@Html.TextBox("[1].FirstName")
- @:LastName:@Html.TextBox("[1].LastName")
- <h3>movies:</h3>
- @:1:@Html.TextBox("movies")<br />
- @:2:@Html.TextBox("movies")<br />
- @:3:@Html.TextBox("movies")<br />
- <div class="form-group">
- <div class="col-md-offset-2 col-md-10">
- <input type="submit" value="Create" class="btn btn-default" />
- </div>
- </div>
- }
说明:
视图中的”@:“表示输出一行纯字符串,或者是一行未闭合的html标记,这个对于不想输出html标记的行非常有用,上面如果没加”@:“就会报错。First Person和Second Person输入的值绑定到参数persons,这个List会有两个类型为Person的对象。这里用了[index].字段名来告诉ASP.NET MVC默认Model Binder来帮我们把输入值绑定到相应类型参数对象的字段上去。movies:输入的值绑定到参数movies,这个List会有三个类型为字符串的元素。
二、ASP.NET MVC中的Model绑定Dictionary集合方法
1、HomeController加上Register的Action:
- public ActionResult Register()
- {
- return View();
- }
- [HttpPost]
- public ActionResult Register(IDictionary<string, Person> people)
- {
- return View();
- }
2、视图,Register.cshtml:
- @model WebApplication1.Models.Person
- @{
- ViewBag.Title = "Register";
- }
- <h2>Register</h2>
- @using (Html.BeginForm())
- {
- <h4>First Person</h4>
- <input type="hidden" name="[0].key" value="firstPerson" />
- @:First Name: @Html.TextBox("[0].value.FirstName")
- @:Last Name: @Html.TextBox("[0].value.LastName")
- <h4>Second Person</h4>
- <input type="hidden" name="[1].key" value="secondPerson" />
- @:First Name: @Html.TextBox("[1].value.FirstName")
- @:Last Name: @Html.TextBox("[1].value.LastName")
- <div class="form-group">
- <div class="col-md-offset-2 col-md-10">
- <input type="submit" value="Submit" class="btn btn-default" />
- </div>
- </div>
- }
说明:
上面其实也是[index].字段名来告诉ASP.NET MVC默认Model Binder来帮我们把输入值绑定到相应类型参数对象的字段上去(键:[0].key,值:[0].value.FirstName)。字段属性key和value,正好是Dictionary的键和值。
最新文章
- 翻译:使用 ASP.NET MVC 4, EF, Knockoutjs and Bootstrap 设计和开发站点 - 5 - 数据库设计
- Python列表去除重复元素
- struts2原理理解
- Swift使用注意
- 几个国内速度最快的centos yum(更新源)
- Java项目中的classpath
- VB 2015 的 闭包(Closure)
- SOCKSify Ruby
- wifi密码破解-Linux工具篇-video
- linux安装
- java 代码格式(转)
- Emoji表情在网页中显示
- webpack 1.x 学习总结
- php调用c/c++时 passthru()被禁用问题
- iOS逆向开发(6):微信伪造位置
- Linux:Gentoo系统的安装笔记(三)
- C#通过COM组件调用IDL的pro程序
- haier周的计算原则
- 学习node.js 第1篇 介绍nodejs
- ShellExecute使用详解