Пример редактирования ASP.NET MVC нескольких дочерних записей
Кто-нибудь знает какие-либо примеры или учебные пособия по представлению MVC, в котором все родительские / дочерние данные отображаются в одной форме и позволяют редактировать все дочерние записи?
Например, скажем, у меня есть таблица людей, а другая содержит автомобили, которыми они владеют. В одной форме я хочу показать каждое транспортное средство для данного человека и сделать элементы данных редактируемыми (например, номерной знак, цвет автомобиля и т. Д.) На случай ошибок. Я не хочу переходить к отдельной форме редактирования для каждого транспортного средства.
До сих пор мои попытки привели меня к тому, что я могу отобразить данные, но не могу отправить их обратно на контроллер. Я пытался сузить проблему настолько далеко, насколько мог, но все еще не понимаю, и думаю, что может быть более широкий пример. Есть идеи?
2 ответа
Вы можете попробовать что-то вроде этого.
Предположим, у вас есть этот объект:
public class Vehicle
{
public int VehicleID { get; set; }
public string LicencePlate { get; set; }
public string Color { get; set; }
}
И это действие вашего контроллера, которое вы будете использовать для редактирования сведений о транспортном средстве (где вы разместите форму):
[AcceptVerbs(HttpVerbs.Post)]
public ActionResult EditVehicles(int Owner, Vehicle[] vehicles)
{
//manipulate the data, then return back to the list
return RedirectToAction("YourAction");
}
Тогда вы должны установить свою форму следующим образом:
<!--have a form for each person, listing their vehicles-->
<form action="/EditVehicles" method="post">
<input type="hidden" name="Owner" value="25" />
<input type="hidden" name="Vehicles[0].VehicleID" value="10" />
<input type="text" name="Vehicles[0].LicencePlate" value="111-111" />
<input type="text" name="Vehicles[0].Color" value="Red" />
<input type="hidden" name="Vehicles[1].VehicleID" value="20" />
<input type="text" name="Vehicles[1].LicencePlate" value="222-222" />
<input type="text" name="Vehicles[1].Color" value="Blue" />
<input type="submit" value="Edit" />
</form>
Это поможет DefaultModelBinder правильно связать данные формы с вашей моделью в вашем контроллере. таким образом Response.Write(vehicles[1].Color);
на вашем контроллере будет напечатано "Blue".
Это очень простой пример, но я уверен, что вы поняли идею. Дополнительные примеры связывания форм с массивами, списками, коллекциями, словарями смотрите здесь.
Я думаю, что лучшее, что вы можете обойти, - это использовать сообщения AJAX. Каждый раз, когда пользователь нажимает кнопку отправки, вы можете подключиться к этому событию, создать JSON-массив вещей, которые вы хотите сохранить, и передать их.
Другой способ, конечно, - получить всю информацию из объекта "FormCollection" в действии POST. Вам просто нужно перебрать все ключи, проанализировать данные и затем обработать их.