Как сделать AutoPostBack в EditItemTemplate? - PullRequest
4 голосов
/ 18 мая 2011

У меня есть пара DropDownLists в FormView EditItemTemplate.Один из них - список брокеров, а другой - список брокерских счетов.Когда DropDownList брокера изменяется, я хочу, чтобы DropDownList счетов заполнялся списком счетов для этого брокера.

Страница начинается следующим образом:

<asp:FormView
    ID="fvwEditTrade"
    DataSourceID="srcTrade" 
    runat="server" 
    DataKeyNames="tradeId" 
    DefaultMode="Edit" 
    CssClass="formView"
    OnItemUpdated="fvwEditTrade_Updated" 
    OnItemCommand="fvwEditTrade_Command" 
    OnItemUpdating="fvwEditTrade_Updating"            
    >
<EditItemTemplate>
    <asp:Label ID="lblTradeId" Text="TradeId: " runat="server" CssClass="label" /><%# Eval("tradeId") %>
    <br />

    <asp:Label ID="lblBroker" Text="Broker" runat="server" CssClass="label" />
    <asp:DropDownList 
    ID="ddlBrokers" 
    runat="server" 
    CssClass="dropdownlist" 
    DataSourceID="srcBrokers" 
    DataTextField="broker" 
    DataValueField="brokerId" 
    SelectedValue='<%# Bind("brokerId") %>'  
    AutoPostBack="true"             
     />
    <br />  

    <asp:Label ID="lblAccount" Text="Account" AssociatedControlID="ddlAccounts" runat="server" CssClass="label" />
    <asp:DropDownList 
    ID="ddlAccounts" 
    runat="server" 
    CssClass="dropdownlist" 
    DataSourceID="srcAccounts" 
    DataTextField="description" 
    DataValueField="accountId" 
    SelectedValue='<%# Bind("accountId") %>' 
     />
    <br />

У меня тогда есть

   <asp:Button
    id="lnkUpdate"
    Text="Update"
    CommandName="Update" CssClass="button"
    Runat="server" />

    <asp:Button
    id="lnkCancel"
    Text="Cancel"
    CommandName="Cancel" CssClass="button"
    Runat="server" />

</EditItemTemplate>
</asp:FormView>            


<CustomControls:CustomObjectDataSource
    id="srcTrade" 
    TypeName="DatabaseComponent.DBUtil" 
    SelectMethod="GetTrade"
    UpdateMethod="UpdateTrade"
    runat="server">
    <SelectParameters>
    <asp:QueryStringParameter Name="tradeId" QueryStringField="tradeId" />               
    </SelectParameters>
    <UpdateParameters>                
    <asp:ControlParameter Name="tradeId" ControlId="fvwEditTrade" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="accountId" ControlId="fvwEditTrade$ddlAccounts" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="symbol" ControlId="fvwEditTrade$ddlSymbols" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="riskProfileId" ControlId="fvwEditTrade$ddlRiskProfiles" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="pctAccountRisked" ControlId="fvwEditTrade$txtPctAccountRisked" PropertyName="Text" />
    <asp:ControlParameter Name="tradeSetupId" ControlId="fvwEditTrade$ddlSetups" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="amountPerUnit" ControlId="fvwEditTrade$txtamountPerUnit" PropertyName="Text" />
    <asp:ControlParameter Name="initialStopPrice" ControlId="fvwEditTrade$txtInitialStopPrice" PropertyName="Text" />
    <asp:ControlParameter Name="tfCode" ControlId="fvwEditTrade$ddlTimeFrames" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="MAEPips" ControlId="fvwEditTrade$txtMAEPips" PropertyName="Text" />
    <asp:ControlParameter Name="MFEPips" ControlId="fvwEditTrade$txtMFEPips" PropertyName="Text" />
    <asp:ControlParameter Name="tradeGrade" ControlId="fvwEditTrade$ddlTradeGrades" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="executionGrade" ControlId="fvwEditTrade$ddlExecutionGrades" PropertyName="SelectedValue" />
    <asp:ControlParameter Name="comment" ControlId="fvwEditTrade$txtComments" PropertyName="Text" />
    </UpdateParameters>
</CustomControls:CustomObjectDataSource>

<CustomControls:CustomObjectDataSource
    id="srcBrokers" 
    TypeName="DatabaseComponent.DBUtil" 
    SelectMethod="GetBrokers" 
    runat="server">
</CustomControls:CustomObjectDataSource>

<CustomControls:CustomObjectDataSource
    id="srcAccounts" 
    TypeName="DatabaseComponent.DBUtil" 
    SelectMethod="GetBrokerAccounts" 
    runat="server">
    <SelectParameters>
    <asp:ControlParameter Name="brokerId" ControlId="fvwEditTrade$ddlBrokers" PropertyName="SelectedValue" />
    </SelectParameters>
</CustomControls:CustomObjectDataSource>        

Когда страница загружается, я получаю эту ошибку:

Databinding methods such as Eval(), XPath(), and Bind() can only be used in the context of a databound control.

Если я перемещаю CustomObjectDataSources srcBrokers и srcAccounts "внутри" EditItemTemplate, страница загружается нормально, ОДНАКО, когда я выбираю брокерав ddlBrokers я снова получаю ту же ошибку:

Databinding methods such as Eval(), XPath(), and Bind() can only be used in the context of a databound control.

Есть идеи, как это исправить?Должны ли источники данных находиться за пределами EditItemTemplate или внутри?

Ответы [ 4 ]

0 голосов
/ 28 февраля 2014
SelectedValue='<%# xx(DataBinder.Eval(Container.DataItem,"fieldname")) %>' 

делает xx такой функцией:

Function xx(ByVal a As String) As String
    Return a
End Function
0 голосов
/ 18 мая 2011

Удалить связывающее выражение SelectedValue='<%# Bind("accountId") %>' из ddlAccounts. Это вызывает проблему. Вы должны справиться с этим из кода позади.

Когда элемент пытается обновить, вы должны передать этот выпадающий список Выбранное значение в FormView ItemUpdating Event

0 голосов
/ 27 февраля 2012

Добавить флаг, когда происходит обновление элемента в FormView. В FormView PreRender проверьте, если (IsPostBack &&! _FvWasUpdated) {formView1.DataBind ();}

Это исправит это. Проблема в том, что FormView не выполняет привязку данных при обратной передаче, и если обратная передача не происходит из самой формы, он потеряет свой текстовый текст данных.

0 голосов
/ 18 мая 2011

Можете ли вы попробовать Eval() вместо Bind()

...