ASP.NET динамические формы MVC
может ли кто-нибудь предложить хороший способ разработки динамических форм с ASP.NET MVC?
У меня есть каскадные выпадающие списки на странице (Параметры в раскрывающемся списке зависят от значения, выбранного в предыдущем раскрывающемся списке).
все значения поступают из базы данных.
Как я могу реализовать такое поведение, используя ASP.NET MVC?
конечно, я хотел бы получить все значения в контроллере, когда я отправляю свою форму.
5 ответов
Если вам нужно иметь некоторые динамические поля в вашей форме, лучшим способом для вас было бы использовать некоторые расширенные рамки javascript, такие как Угловое, основой, офф etc.
Если вам нужно что-то более или менее простое, вам достаточно использовать нокаут. Для более продвинутых сценариев я бы рекомендовал Angular, но это мое личное предпочтение.
вот простая реализация динамической формы с Нокаут:
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 и post JSON для ASP.NET действие MVC. Прежде всего, вам нужно будет получить объект JSON из вашей формы. С нокаутом все очень просто:
var json = ko.toJSON(model);
теперь, когда мы знаем, как получить JSON из формы, следующий шаг-отправить ваши данные в действие. 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
}
это, безусловно, не единственный вариант реализации динамических форм, но я думаю, что это довольно эффективно. Надеюсь, это поможет.
вы можете сделать это очень легко с помощью мои 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.
}
``
можно использовать FormCollection в качестве параметра для получения всех данных, которые поступают в форме:
[HttpPost]
public ActionResult ActionName(FormCollection collection)
{
//collection["inputName"];
}
Я бы создал частичные представления для каждой опции раскрывающегося списка и дополнительных полей. Чем контроллер, который вернет такие части html согласно выпадающему значению:
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
}
);
попробуйте это http://mvcdynamicforms.codeplex.com/releases/view/43320 это должно быть полезно