有人能否建议一种使用ASP.NET MVC开发动态表单的好方法?
页面上有级联下拉框(下拉框中的选项取决于前一个下拉框中选择的值)。
所有值都来自数据库。
我如何使用ASP.NET MVC实现这种行为?
当提交表单时,当然我想在控制器中接收所有值。
有人能否建议一种使用ASP.NET MVC开发动态表单的好方法?
页面上有级联下拉框(下拉框中的选项取决于前一个下拉框中选择的值)。
所有值都来自数据库。
我如何使用ASP.NET MVC实现这种行为?
当提交表单时,当然我想在控制器中接收所有值。
您可以使用FormCollection作为参数来接收来自表单的所有数据:
[HttpPost]
public ActionResult ActionName(FormCollection collection)
{
//collection["inputName"];
}
你可以很容易地使用我的FormFactory库来实现此功能。
默认情况下,它会反射一个视图模型以生成一个PropertyVm[]
数组:
```
var vm = new MyFormViewModel
{
OperatingSystem = "IOS",
OperatingSystem_choices = new[]{"IOS", "Android",};
};
Html.PropertiesFor(vm).Render(Html);
但是您也可以通过编程的方式创建属性,因此您可以从数据库加载设置,然后创建 PropertyVm
。
这是来自 Linqpad 脚本的片段。
```
//import-package FormFactory
//import-package FormFactory.RazorGenerator
void Main()
{
var properties = new[]{
new PropertyVm(typeof(string), "username"){
DisplayName = "Username",
NotOptional = true,
},
new PropertyVm(typeof(string), "password"){
DisplayName = "Password",
NotOptional = true,
GetCustomAttributes = () => new object[]{ new DataTypeAttribute(DataType.Password) }
}
};
var html = FormFactory.RazorEngine.PropertyRenderExtension.Render(properties, new FormFactory.RazorEngine.RazorTemplateHtmlHelper());
Util.RawHtml(html.ToEncodedString()).Dump(); //Renders html for a username and password field.
}
这里有一个演示站点,展示了各种功能的示例,例如嵌套集合、自动完成、日期选择等等。
using (var form = Html.FormForAction((HomeController c, string p0, string p1, bool p2, string p3) => c.SignIn(p0, p1, p2, p3)))
有4个变量,但动作只需要3个变量,2)第二个表单中的提交是如何执行的,请您可否详细展开文档说明?3)我该如何使用Lat Long、Fa-Icons? - aggievar 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>
这更加棘手。也许最好、最简单的方法是使用Ajax并将JSON发布到ASP.NET MVC操作。首先,您需要从表单中获取一个JSON对象。使用knockout非常简单:
var json = ko.toJSON(model);
$.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
});
[HttpPost]
public JsonResult AddUser(List<string> users)
{
return Json(data); // return something
}
public class FormFieldsController : Controller
{
public ActionResult Index(string dropDownOption)
{
if(dropDownOption == "Option1")
return PartialView("PartialForOption1");
etc.//
}
}
然后只需使用 jQuery Ajax 调用它,并在下拉菜单更改时将当前表单附加到操作结果。
$.ajax("/FormFields/Index",
{
async: false,
data: { dropDownOption: $('#dropDownId').value()},
success: function(data) {
if (callback == null) {
$("#form").append(data);
} else {
callback(data);
}
},
error: function() {
alert('Error');
},
type: 'GET',
timeout: 10000
}
);
看一下这个库:
使用Bootstrap支持的.NET CRUD,可以根据数据字典在运行时创建表单。 适用于.net 7或fmk 4.8