TargetInvocationException: исключение было выдано целью вызова.на привязке данных - PullRequest
1 голос
/ 20 июля 2010

Я пытаюсь привязать GridView к источнику данных по событию RowEditing, но выдает исключение:

[TargetInvocationException: Исключение было сгенерировано целью вызова.] Методы привязки данных, напримерEval (), XPath () и Bind () могут использоваться только в контексте элемента управления с привязкой к данным.

lblackout = EXMailbox.GetBlackouts();
BlackoutGridView.DataSource=lblackout;


protected void BlackoutGridView_RowEditing(object sender, GridViewEditEventArgs e)
{
        BlackoutGridView.EditIndex = e.NewEditIndex;
        BlackoutGridView.DataSource = lblackout;  //Throws exception here.
        BlackoutGridView.DataBind();
}


            <asp:GridView ID="BlackoutGridView" runat="server" AutoGenerateColumns="False" 
                OnRowDeleting="BlackoutGridView_RowDeleting" 
                OnRowEditing="BlackoutGridView_RowEditing" 
                onrowcancelingedit="BlackoutGridView_RowCancelingEdit">                            
                <Columns>
                    <asp:BoundField DataField="BlackoutId" HeaderText="BlackoutId" >
                    </asp:BoundField>
                    <asp:TemplateField HeaderText="Region">
                        <EditItemTemplate>
                        <asp:DropDownList ID="DropDownList11" runat="server" Text='<%# Bind("Region") %>' 
                                DataSourceID="lblackout" DataTextField="Region" DataValueField="Region"></asp:DropDownList>
                            <asp:ObjectDataSource ID="lblackout" runat="server" SelectMethod="GetDataItem" 
                                TypeName="Exchange.MailboxMove.WebUI.BlackoutScreen"></asp:ObjectDataSource>
                        </EditItemTemplate>
                        <ItemTemplate>
                            <asp:Label ID="Label1" runat="server" Text='<%# Bind("Region") %>'></asp:Label>
                        </ItemTemplate>
                    </asp:TemplateField>
                    <asp:BoundField HeaderText="Server" DataField="Server">
                    </asp:BoundField>
                    <asp:BoundField HeaderText="From Date" DataField="StartDateTime" 
                        DataFormatString="{0:D}">
                    </asp:BoundField>
                    <asp:BoundField HeaderText="To Date" DataField="EndDateTime" 
                        DataFormatString="{0:D}">
                    </asp:BoundField>
                    <asp:BoundField HeaderText="From Time" DataField="StartDateTime" 
                        DataFormatString="{0:t}">
                    </asp:BoundField>
                    <asp:BoundField HeaderText="To Time" DataField="EndDateTime" 
                        DataFormatString="{0:t}">
                    </asp:BoundField>
                    <asp:CheckBoxField HeaderText="IsWeekly" DataField="IsWeekly">
                    </asp:CheckBoxField>
                    <asp:CommandField DeleteText="Cancel" HeaderText="Action" 
                        ShowDeleteButton="True" ShowEditButton="True" ShowHeader="True" >
                    </asp:CommandField>

1 Ответ

0 голосов
/ 10 августа 2011

согласно вашему коду, я думаю, что вы пропустили поле DataValue для Gridview.

Это образец из MSDN, как связать выпадающий список

<asp:DropDownList ID="InsertCategoryDropDownList" 
                          DataSourceID="CategoriesDataSource"
                          DataTextField="CategoryName"
                          DataValueField="CategoryID"
                          RunAt="Server" />

Без поля DataValue, редактирование строк и другие события не будут выполнять логику. Я надеюсь, что помог тебе. Вы также можете проверить MSDN для SqlDatasource http://msdn.microsoft.com/en-us/library/system.web.ui.webcontrols.sqldatasource.aspx

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...