ASP.NET MVC пример редактирования нескольких дочерних записей - PullRequest
23 голосов
/ 02 апреля 2009

Кто-нибудь знает какие-либо примеры или учебные пособия по представлению MVC, в котором все родительские / дочерние данные отображаются в одной форме и позволяют редактировать все дочерние записи?

Например, скажем, у меня есть таблица людей, а другая содержит автомобили, которыми они владеют. В одной форме я хочу показать каждое транспортное средство для данного человека и сделать элементы данных редактируемыми (например, номерной знак, цвет автомобиля и т. Д.) На случай ошибок. Я не хочу переходить к отдельной форме редактирования для каждого транспортного средства.

Мои попытки до сих пор привели меня к тому, что я могу отобразить данные, но не могу отправить их обратно на контроллер. Я пытался сузить проблему настолько, насколько смог здесь , но я все еще не понимаю, и я думаю, что более широкий пример может быть в порядке. Есть идеи?

Ответы [ 2 ]

27 голосов
/ 03 апреля 2009

Вы можете попробовать что-то вроде этого.

Предположим, у вас есть этот объект:

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».

Это очень простой пример, но я уверен, что вы поняли идею. Дополнительные примеры связывания форм с массивами, списками, коллекциями, словарями см. В разделе здесь .

0 голосов
/ 03 апреля 2009

Я думаю, что лучшее, что вы можете обойти - это использовать AJAX-посты. Когда пользователь нажимает кнопку отправки, вы можете подключить это событие, создать массив JSON с теми вещами, которые вы хотите сохранить, и передать их.

Другой способ - это получить всю информацию из объекта FormCollection в действии POST. Вам просто нужно перебрать все ключи, проанализировать данные и затем обработать их.

...