0

次のエンティティオブジェクトの例があります

class Entity
{
   public string Name { get; set; }

   public IList<string> Fields { get; set; }
}

これで、データグリッドにバインドされた詳細ビューがあり、どちらもnameプロパティを適切に表示/編集できますが、fieldsプロパティも編集できるようにしたいと思います。

これを行うには、複数行のテキストボックスを使用したいと思っていました。したがって、各行はフィールドリストの項目に対応します。しかし、リストをテキストボックスにバインドして、各アイテムが新しい行に表示されるようにする方法に問題があります。手動で行うので、詳細を取り出してオブジェクトに戻し、後で保存するという問題はないと思います。

したがって、問題は、詳細ビューのテキストボックスでカスタムバインドを実行して、各IListアイテムが別々の行に表示されるようにする方法はありますか?

4

4 に答える 4

0

次のようなものを試してください

[AcceptVerbs(HttpVerbs.Post)]
public ActionResult Edit(string[] Fields)
{
// do something with Fields array
}
于 2009-11-12T11:51:48.667 に答える
0

正解は次のようです。

コードでaspxページをバインドし、次のようにメソッドを作成します。

public string CustomBind(object data)
{
   if(data is List<string>)
   {
      List<string> list = data as List<string>;

      return string.Join("\n", list.ToArray();
   }
}

次に、aspxページで、テキストボックスに対して次の手順を実行してバインドします。

<asp:Textbox TextMode="MultiLine" Text='CustomBind(Eval("MyList"))'></asp:TextBox>

初心者のASP.NETEvalの質問の質問でこの回答を提供してくれたDaveに感謝します。

于 2009-11-12T11:43:27.983 に答える
0

あなたが求めているのは、ネストされたListViewのようなものです。これらのものをネストするのは面倒になりますが、これは機能するはずです。

<asp:GridView runat="server" ID="EntityGridView" AutoGenerateColumns="False" 
        EditIndex="0" OnRowUpdating="EntityGridView_RowUpdating">
        <Columns>
            <asp:TemplateField HeaderText="Name">
                <ItemTemplate>
                    <asp:Label ID="NameLabel" runat="server" Text='<%# Bind("Name") %>'></asp:Label>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="NameTextBox" runat="server" Text='<%# Bind("Name") %>'></asp:TextBox>
                </EditItemTemplate>
            </asp:TemplateField>
            <asp:TemplateField>
                <ItemTemplate>
                    <asp:GridView runat="server" DataSource='<%# Eval("Fields") %>'/>
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:ListView runat="server" DataSource='<%# Eval("Fields") %>' ID="FieldListView">
                        <LayoutTemplate>
                            <asp:PlaceHolder ID="itemPlaceholder" runat="server" />
                        </LayoutTemplate>
                        <ItemTemplate>
                            <asp:TextBox Text='<%# Container.DataItem %>' runat="server" ID="FieldValue"/><br />
                        </ItemTemplate>
                    </asp:ListView>
                </EditItemTemplate>
            </asp:TemplateField>
            <asp:CommandField  ShowEditButton="True" />
        </Columns>
    </asp:GridView>

また、更新方法は次のようになります。

protected void EntityGridView_RowUpdating(object sender, GridViewUpdateEventArgs e)
{
    var updatedEntity = new Entity {Fields = new List<string>()};

    var row = EntityGridView.Rows[e.RowIndex];

    var nameTextBox = (TextBox) row.FindControl("NameTextBox");
    updatedEntity.Name = nameTextBox.Text;

    var fieldListView = (ListView) row.FindControl("FieldListView");
    foreach (var dataItem in fieldListView.Items)
    {
        var fieldValueTextBox = (TextBox)dataItem.FindControl("FieldValue");
        updatedEntity.Fields.Add(fieldValueTextBox.Text);
    }

    // Do your save etc here
}

次に、エンティティのリストをGridViewにバインドするだけです。

于 2009-11-12T11:45:41.333 に答える
0

拡張メソッドを使用することもできるので、すべてのページでこのタスクのメソッドを明示的に作成する必要はありません。

<asp:TextBox TextMode="MultiLine" ID="txtQuotes" runat="server" Text='<%# ((List<String>) Eval("Quotes")).ToMultiLine() %>' />

 public static class ExtensionMethods
    {      

        public static string ToMultiLine(this List<String> list)
        {
            return String.Join("\n", list.ToArray()); 
        }


    }
于 2009-11-12T16:50:29.423 に答える