DetailsView не перейдет в режим редактирования - PullRequest
3 голосов
/ 11 октября 2011

Мне не удается открыть окно с подробностями, чтобы войти в режим редактирования.Я программно привязываю источник данных.Когда команда элемента «редактировать», я изменяю режим на «редактировать» и перепривязываю источник данных.Я проверил после привязки данных элемента управления, и он все еще находится в режиме редактирования, но представление сведений не отображается в режиме редактирования.Любая помощь будет принята с благодарностью.В настоящее время мое представление данных упрощено до одного элемента для тестирования.(это перекрестная публикация на форумах ASP.NET, так как я мог бы использовать некоторую помощь относительно скоро)

ASPX:

<div style="width:990px;height:430px;">
    <div style="width:650px;height:430px;float:left;">
    <telerik:RadAjaxLoadingPanel ID="devicesLoadingPanel" runat="server" Skin="Simple" />
    <telerik:RadGrid ID="devicesRadGrid" runat="server" Skin="Simple" AllowPaging="true" Width="550" PageSize="15"
    AutoGenerateColumns="false"  DataSourceID="SqlDataSource1" OnSelectedIndexChanged="devicesGrid_SelectedIndexChanged">
        <MasterTableView DataKeyNames="ID" CommandItemDisplay="Top">
            <Columns>
                <telerik:GridTemplateColumn HeaderText="Type" SortExpression="Type">
                    <ItemTemplate>
                        <asp:Label ID="lblType" runat="server" Text='<%# evalLabelType((Eval("UnitType"))) %>' />
                    </ItemTemplate>
                </telerik:GridTemplateColumn>
                <telerik:GridBoundColumn HeaderText="Name" DataField="Name" SortExpression="Name"></telerik:GridBoundColumn>
                <telerik:GridBoundColumn HeaderText="Description" DataField="Description" SortExpression="Description"></telerik:GridBoundColumn>
                <telerik:GridTemplateColumn HeaderText="Location">
                    <ItemTemplate>
                        <asp:Label ID="lblDevicesLocation" runat="server" Text='<%# evalDevicesLocation(Eval("LocationID")) %>' />  
                    </ItemTemplate>
                </telerik:GridTemplateColumn>
            </Columns>
        <CommandItemSettings ShowAddNewRecordButton="true" ShowRefreshButton="false"  />
        </MasterTableView>
        <ClientSettings EnablePostBackOnRowClick="true">
            <Selecting AllowRowSelect="true" />
        </ClientSettings>
    </telerik:RadGrid>

    </div>
    <div style="border: 1px solid #000;width:250px;height:430px;float:left;" >
        <asp:DetailsView ID="devicesDetailsView" runat="server" AutoGenerateRows="false" Width="200" Height="430" 
         CellPadding="0" GridLines="None" 
         OnItemCommand="devicesDetails_ItemCommand" OnDataBound="devicesDetails_DataBound">
            <Fields>
                <asp:TemplateField>
                    <ItemTemplate>
                        <span class="titles">Type:</span>
                        <asp:Label ID="lblType" runat="server" Text='<%# evalLabelType((Eval("UnitType"))) %>' />
                    </ItemTemplate>
                    <EditItemTemplate>
                        <span class="titles">Type:</span>
                        <asp:TextBox ID="txtType" runat="server" Text="test" />
                    </EditItemTemplate>
                </asp:TemplateField>

                <asp:CommandField ShowEditButton="true" ButtonType="Button" />
            </Fields>
        </asp:DetailsView>
    </div>

C #:

    protected void devicesGrid_SelectedIndexChanged(object sender, EventArgs e)
    {
        devicesDataKey = devicesRadGrid.SelectedItems[0].OwnerTableView.DataKeyValues[devicesRadGrid.SelectedItems[0].ItemIndex]["ID"].ToString();
        devicesDetailsView.DataSource = getDS(); 
        devicesDetailsView.DataBind();
    }

    protected void devicesDetails_ItemCommand(object sender, DetailsViewCommandEventArgs e)
    {
        if (e.CommandName == "Edit")
        {
            // Switch mode and rebind
            devicesDetailsView.ChangeMode(DetailsViewMode.Edit);
            devicesDetailsView.DataSource = getDS();
            devicesDetailsView.DataBind(); 
        }
    }



    protected void devicesDetails_DataBound(object sender, EventArgs e)
    {

        //HideShowFields(devicesDataKey);  

        // Checking the mode again
        string test22 = devicesDetailsView.CurrentMode.ToString();
    }



    protected DataTable getDS()
    {

        string ID = devicesDataKey;

        // Get that device type!
        SqlCommand getDeviceType = new SqlCommand("SELECT UnitType FROM dbo.unit WHERE ID='" + ID + "'", connection);

        connection.Open();
        devicesTypeID = getDeviceType.ExecuteScalar().ToString();
        connection.Close();
        getDeviceType.Dispose(); 

        // This for attenuation. Depending on the device type it may pull from a different table.
        if (devicesTypeID == "2" || devicesTypeID == "3" || devicesTypeID == "4")
        {
            SqlCommand cmd = new SqlCommand("SELECT UnitType,Unit.Active,Name, Description, PrinterName, PrinterPort, PrinterIP, Unit.IPAddress, Unit.ID, LockHoldTimeout,LightOnTimeout, DoorAlertTimeout, EnableEmergAccess, EnableBizHours, ReaderAttenuation, Attenuation, Unit.LocationID, ScanTime FROM dbo.Unit INNER JOIN dbo.Readers on Unit.ID = Readers.UnitID WHERE Unit.ID='" + ID + "'", connection);
            DataTable dt = new DataTable();
            connection.Open();
            using (cmd)
            {
                SqlDataAdapter da = new SqlDataAdapter(cmd);
                da.Fill(dt);
            }
            connection.Close();
            // Attach the data to the details view
            return dt;
        }
        if (devicesTypeID == "5" || devicesTypeID == "6")
        {
            SqlCommand cmd = new SqlCommand("SELECT UnitType,Unit.Active,Name, Description, PrinterName, PrinterPort, PrinterIP, Unit.IPAddress, Unit.ID, LockHoldTimeout,LightOnTimeout, DoorAlertTimeout, EnableEmergAccess, EnableBizHours, ReaderAttenuation, Unit.LocationID, ScanTime, Attenuation FROM dbo.Unit, dbo.Readers WHERE Unit.ID='" + ID + "'", connection);
            DataTable dt = new DataTable();
            connection.Open();
            using (cmd)
            {
                SqlDataAdapter da = new SqlDataAdapter(cmd);
                da.Fill(dt);
            }
            connection.Close();
            // Attach the data to the details view
            return dt;
        }

        return null; 
    }

Ответы [ 2 ]

1 голос
/ 13 октября 2011

Я понял это, оказалось, что мой Telerik Ajax Manager скрывал ошибку, которую я получал. Я получал «Событие DetailsChanging с запущенным событием DetailsView», которое я решил, используя инструкции по следующей ссылке: forums.asp.net

0 голосов
/ 20 июля 2015

Простое резюме по ссылке на форуме asp.net, которое @Will упоминает:

protected void dvSupplier_ModeChanging(object sender, DetailsViewModeEventArgs e)
    {
        dvSupplier.ChangeMode(e.NewMode);
        this.SetData();
    }
...