我想知道人們對Phil Haack's Model Binding To A List做出相反處理的最佳方式的想法。我有一個表單,它包含幾個單獨的字段以及使用JQuery動態創建的表單字段。這意味着,當我查詢數據庫以進行編輯時,它將返回一個對象,該對象本身會附加n個對象(每個對象都相同)。「模式綁定到列表」的對面
我想知道人們會建議做什麼來創建窗體的「動態」部分,特別是確保爲下拉列表選擇正確的項目。我有一個模糊的想法,它將涉及查看用戶控制,但我正在努力如何把它放在一起。
形式:從隱藏輸入到第二選擇列表的末尾
<form action="/MyItems/Edit" method="post">
Title: <input type="text" name="Title" value="" /><br />
Description <input type="text" name="Description" value="" /><br /><br />
<input type="hidden" name="myItem.Index" value="0" />
<input id="item[0].Amount" name="item[0].Amount" type="text" value="" />
<select id="item[0].selectA"><option value="1">1</option>
<option value="2">2</option><option value="3">3</option></select>
<select id="item[0].selectB"><option value="1">1</option>
<option value="2">2</option><option value="3">3</option></select>
<input type="hidden" name="myItem.Index" value="1" />
<input id="item[1].Amount" name="item[1].Amount" type="text" value="" />
<select id="item[1].selectA"><option value="1">1</option>
<option value="2">2</option><option value="3">3</option></select>
<select id="item[1].selectB"><option value="1">1</option>
<option value="2">2</option><option value="3">3</option></select>
<input type="hidden" name="myItem.Index" value="2" />
<input id="item[2].Amount" name="item[2].Amount" type="text" value="" />
<select id="item[2].selectA"><option value="1">1</option>
<option value="2">2</option><option value="3">3</option></select>
<select id="item[2].selectB"><option value="1">1</option>
<option value="2">2</option><option value="3">3</option></select>
</form>
一切可以重複n次。即正在從數據庫查詢水合的DTO如下所示:
public class MyItem
{
public string Name { get; set; }
public string Description { get; set; }
public IEnumerable<SelectItem> SelectItems { get; set; }
}
每個SelectItem
則看起來像:
public class SelectItem
{
public int SelectA { get; set; }
public int SelectA { get; set; }
}
我希望我已經解釋了這行,在此先感謝任何人服用有時間看看這個。
謝謝長頸鹿,明天早上我會好好看看,一定會回來。 – dave 2009-01-20 09:36:41