任何人都可以建议用ASP.NET MVC开发动态表单的好方法吗?
我在页面上有级联下拉列表(下拉列表中的选项取决于在上一个下拉列表中选择的值).
所有值都来自数据库.
如何使用ASP.NET MVC实现此类行为?
当然,我希望在提交表单时收到控制器中的所有值.
解决方法
如果您需要在表单中包含一些动态字段,最好的方法是使用一些高级的javascript框架,如
Angular,Backbone,Knockout等.
如果你需要或多或少的东西,你就可以使用Knockout了.对于更高级的场景,我会推荐Angular,但这是我个人的偏好.
以下是使用Knockout的动态表单的简单实现:
var model = { users: ko.observableArray(),addUser: function() { this.users.push({ name: ko.observable() }); } }; ko.applyBindings(model);
<script src="https://cdnjs.cloudflare.com/ajax/libs/knockout/3.2.0/knockout-min.js"></script> <div data-bind="foreach: users"> <input type="text" data-bind="value: name" /><br /> </div> <button data-bind="click: addUser">Add user</button> <ul data-bind="foreach: users"> <li data-bind="text: name"></li> </ul>
现在,ASP.NET MVC怎么样?
这更棘手.也许最好也是最简单的方法是使用Ajax并将JSON发布到ASP.NET MVC Action.首先,您需要从表单中获取JSON对象.淘汰赛很简单:
var json = ko.toJSON(model);
现在,当我们知道如何从表单中获取JSON时,下一步是将数据发送到Action. jQuery非常适合:
$.ajax({ type: "POST",url: "@Url.Action("AddUser")",data: ko.toJSON(model).users,// Serialize to JSON and take users array accept: 'application/json',success: function (data) { alert("Done!"); } // Your success callback });
在我们的例子中,我们基本上发送一个字符串数组,因此ASP.NET MVC操作应该如下所示:
[HttpPost] public JsonResult AddUser(List<string> users) { return Json(data); // return something }
这绝对不是如何实现动态表单的唯一选择,但我认为它非常有效.希望能帮助到你.