将DropDownList绑定到GridView的EditItemTemplate中的EntityDataSource

时间:2012-01-10 15:47:42

标签: entity-framework webforms entitydatasource

关于这个问题有很多问题,但我不相信我的具体问题。我有一个可通过gridview编辑的EntitySet。它显示很好。但是,我有两个下拉列表必须处理外键关系。这可以在同一页面上的formview中进行插入。有一次,我在网格的编辑视图中工作了。

这是在ASP.Net 3.5(实体框架1)中。我使用了Julie Lerman的实体框架书(第11章)第286页的一个例子。

我得到的错误是“数据绑定方法,如Eval(),XPath()和Bind()只能在数据绑定控件的上下文中使用。”

我发现的大多数帖子都与Eval相关,而不是Bind。代码在显示模式下工作(将Eval作为标签),但切换到编辑模式时会出现错误。

任何帮助将不胜感激。如果我能提供更多信息,请告诉我。

<asp:EntityDataSource
        ID="dsChargePrintMappings"
        ConnectionString="name=RateModelConnectionString"
        DefaultContainerName="RateEntities"
        EntitySetName="ChargePrintMappings"
        Include="ChargeType, BillPrintGroup"
        OrderBy="it.[EffectiveDate], it.[EffectiveEndDate]"
        EnableDelete="true"
        EnableUpdate="true"
        EnableInsert="true"
        runat="server" />

<asp:EntityDataSource
        ID="dsChargeType"
        ConnectionString="name=RateModelConnectionString"
        DefaultContainerName="RateEntities"
        EntitySetName="ChargeTypes"
        runat="server" />

    <asp:GridView
        ID="gvChargePrintMappings"
        DataSourceID="dsChargePrintMappings"
        DataKeyNames="Id"
        AutoGenerateColumns="false"
        runat="server">
        <AlternatingRowStyle CssClass="alternate" />
        <Columns>
            <asp:BoundField HeaderText="Id" ReadOnly="true" DataField="Id"
/>

            <asp:TemplateField HeaderText="Charge Type">
                <ItemTemplate>
                    <asp:Label ID="lbRate" Text='<%# Eval
("ChargeType.Description") %>' runat="server" />
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:DropDownList
                        ID="ddChargeType"
                        DataSourceId="dsChargeType"
                        DataTextField="Description"
                        DataValueField="Id"
                        SelectedValue='<%# Bind("ChargeType.Id") %>'
                        AppendDataBoundItems="True"
                        runat="server">
                        <asp:ListItem Selected="True" Value="">(none)</asp:
ListItem>
                     </asp:DropDownList>
                </EditItemTemplate>
            </asp:TemplateField>

稍后在页面中我有一个与insert一起使用的formview:

<asp:FormView ID="fvRate" DataSourceID="dsForm" DefaultMode="ReadOnly"
runat="server">
        <EmptyDataTemplate>
            <asp:Button ID="btnInsert" Text="Create New" CommandName="New"
runat="server" />
        </EmptyDataTemplate>
        <InsertItemTemplate>
            <asp:Label ID="lblEffectiveDate" Text="Effective Date:"
AssociatedControlID="txtEffectiveDate" runat="server" />
            <asp:TextBox ID="txtEffectiveDate" onfocus="$(this).datepicker ()" Text='<%# Bind("EffectiveDate") %>' runat="server" /><br>

            <asp:Label ID="lblEffectiveEndDate" Text="Effective End Date:"
AssociatedControlID="txtEffectiveEndDate" runat="server" />
            <asp:TextBox ID="txtEffectiveEndDate" onfocus="$ (this).datepicker()" Text='<%# Bind("EffectiveEndDate") %>' runat="server"
/><br>

            <asp:Label ID="lblChargeType" Text="Charge Type:"
AssociatedControlID="ddChargeType" runat="server" />
            <asp:DropDownList
                ID="ddChargeType"
                DataSourceId="dsChargeType"
                DataTextField="Description"
                DataValueField="Id"
                SelectedValue='<%# Bind("ChargeType.Id") %>'
                AppendDataBoundItems="True"
                runat="server">
                <asp:ListItem Selected="True" Value="">(none)</asp:ListItem
>
             </asp:DropDownList><br>

            <asp:Label ID="lblBillPrintGroup" Text="Bill Print Group:"
AssociatedControlID="ddBillPrintGroup" runat="server" />
            <asp:DropDownList
                ID="ddBillPrintGroup"
                DataSourceId="dsBillPrintGroup"
                DataTextField="Description"
                DataValueField="Id"
                SelectedValue='<%# Bind("BillPrintGroup.Id") %>'
                AppendDataBoundItems="True"
                runat="server">
                <asp:ListItem Selected="True" Value="">(none)</asp:ListItem
>
             </asp:DropDownList><br>


            <asp:Button ID="btnInsert" CommandName="Insert" Text="Create"
runat="server" />
            <asp:Button ID="btnCancelUpdate" CommandName="Cancel" Text ="Cancel" runat="server" />
        </InsertItemTemplate>
    </asp:FormView>

2 个答案:

答案 0 :(得分:1)

在回答中重新创建我的评论,以便我可以格式化: 仅仅是一个FYI,我打开了该书中的相关样本(第1版和样本是3.5,因此使用VS2008来运行它)。编辑和保存使用下拉列表中的值没有问题:

<asp:TemplateField HeaderText="PrimaryActivity" SortExpression="PrimaryActivity">
  <EditItemTemplate>
    <asp:DropDownList runat="server" ID="act1DDL" 
         DataTextField="ActivityName" 
         DataValueField="ActivityID" 
         DataSourceID="EntityDataSource5" 
         AppendDataBoundItems="True" 
         SelectedValue='<%# Bind("PrimaryActivity.ActivityID") %>'>
        <asp:ListItem Value="">*</asp:ListItem>
     </asp:DropDownList>
  </EditItemTemplate>
  <ItemTemplate>
      <asp:Label ID="Label1" runat="server" 
                 Text='<%# Bind("PrimaryActivity.ActivityName") %>'></asp:Label>
  </ItemTemplate>
</asp:TemplateField>

我知道“在我的电脑上工作”并没有太大帮助,但还有其他事情正在发生。也许我通过Twitter发送的链接可能有用吗?

http://aspadvice.com/blogs

答案 1 :(得分:0)

事实证明,绑定到Grid的FormView(和它的DataSource)导致了问题。我离开了来自GridView的SelectedValue的Id参数,但由于GridView是可编辑的,因此尝试以两种可编辑方式绑定记录时遇到问题。

具体来说,我需要从GridView中删除DataKeyNames属性,以及引用GridView的FormView DataSource中的任何参数。

由于FormView仅用于插入,因此它必须是默认模式,因此它是可见的。当没有绑定到GridView时,EmptyItemTemplate不可见,所以我使用了一个按钮和jquery-ui来隐藏和显示formview(它始终处于插入模式)。