0

checkchanged イベント ハンドラーの使用に問題があります。以下は私のシナリオです:

aspxgridview 内にある gridviewdatacheckcolumn 内にある DataItemTemplate 内に aspxcheckbox があります。

これが私のaspxコードです:

<dx:ASPxGridView ID="gvCustomerCertificates" runat="server" AutoGenerateColumns="False" Caption="Customer Certificates" Width="100%">
                                <Columns>
                                    <dx:GridViewDataTextColumn FieldName="CertNo" ShowInCustomizationForm="True" 
                                        VisibleIndex="1" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataTextColumn FieldName="CustManufacturer" Caption="Manufacturer" ShowInCustomizationForm="True"
                                        VisibleIndex="2" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataTextColumn FieldName="CustDesc" Caption="Description" 
                                        ShowInCustomizationForm="True" VisibleIndex="3" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataTextColumn FieldName="CustModel" Caption="Model" 
                                        ShowInCustomizationForm="True" VisibleIndex="4" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataTextColumn FieldName="CustSerialNo" Caption="Serial No" ShowInCustomizationForm="True"
                                        VisibleIndex="5" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataTextColumn FieldName="CustControlNo" Caption="Control No" ShowInCustomizationForm="True"
                                        VisibleIndex="6" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataDateColumn FieldName="CalDate" ShowInCustomizationForm="True"
                                        VisibleIndex="7" ReadOnly="True">
                                        <PropertiesDateEdit DisplayFormatString="MM/dd/yyyy">
                                        </PropertiesDateEdit>
                                        <HeaderStyle Font-Bold="True" />
                                    </dx:GridViewDataDateColumn>
                                    <dx:GridViewDataTextColumn FieldName="CustAssetNo" Caption="Asset No" ShowInCustomizationForm="True"
                                        VisibleIndex="8" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>


                                     <dx:GridViewDataCheckColumn FieldName="Verified" Caption="Verified" ShowInCustomizationForm="True"
                                        VisibleIndex="9" >

                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                        <DataItemTemplate>
                                            <dx:ASPxCheckBox ID="chk" runat="server" AutoPostBack="True" OnCheckedChanged="check_Changed" ClientInstanceName="chk" Enabled="True" >
                                            </dx:ASPxCheckBox>
                                         </DataItemTemplate>       


                                    </dx:GridViewDataCheckColumn>


                                    <dx:GridViewDataTextColumn FieldName="VerifiedInitials" Caption="Initials" ShowInCustomizationForm="True"
                                        VisibleIndex="10">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                    </dx:GridViewDataTextColumn>
                                    <dx:GridViewDataHyperLinkColumn FieldName="PDFName" Caption="PDF" ShowInCustomizationForm="True"
                                        VisibleIndex="11" ReadOnly="True">
                                        <HeaderStyle Font-Bold="True"></HeaderStyle>
                                        <PropertiesHyperLinkEdit Target="_blank" Text="View">
                                            <Style ForeColor="#1FB259"></Style>
                                        </PropertiesHyperLinkEdit>
                                    </dx:GridViewDataHyperLinkColumn>
                                </Columns>
                                <Settings ShowFilterBar="Visible" ShowFilterRow="True" ShowHeaderFilterButton="True" />
                                <SettingsText EmptyDataRow="Currently no Certificates available for your account." />


                            </dx:ASPxGridView>

コードビハインドでcheckedChangedイベントを取得してメソッド「Check_Changed」を呼び出そうとしていますが、イベントハンドラーが起動されません。

コードビハインドの check_Changed メソッドは次のとおりです。

Protected Sub check_Changed(ByVal sender As System.Object, ByVal e As System.EventArgs)

    'test to see if event handler is firing
    MsgBox("Hey")

    Dim cb As ASPxCheckBox = TryCast(sender, ASPxCheckBox)

    Dim container As GridViewDataItemTemplateContainer = TryCast(cb.NamingContainer, GridViewDataItemTemplateContainer)
    cb.ClientInstanceName = String.Format("cbCheck{0}", container.VisibleIndex)
    cb.Checked = gvCustomerCertificates.Selection.IsRowSelected(container.VisibleIndex)


    ' creates a sql connection and opens it
    Dim scSQLConnection As SqlConnection = New SqlConnection() With {.ConnectionString = ConfigurationManager.ConnectionStrings.Item("Main").ConnectionString}
    scSQLConnection.Open()

    ' create a data table
    Try

        Dim sqlCommand As New SqlCommand() With {.CommandText = "INSERT INTO tblVerified VALUES (" + gvCustomerCertificates.Columns.Item("CertNo").ToString}

        Dim daCommand As SqlDataAdapter = New SqlDataAdapter(sqlCommand)
        daCommand.SelectCommand.Connection = scSQLConnection
        sqlCommand.CommandTimeout = 0
        sqlCommand.ExecuteNonQuery()

    Catch ex As Exception

    Finally

    End Try

    scSQLConnection.Close()

End Sub

現在、私がやろうとしているのは、メッセージボックスを表示して、イベントがトリガーされていることを確認することだけです。最終的な目標は、チェックボックスがクリックされたときにデータベースにレコードを挿入することです。別のテーブルにレコードを挿入していますグリッドビューにバインドされているため、フィールドをテーブルにバインドするのではなく、insert ステートメントを使用する必要があります。

ご不明な点がございましたら、お気軽にお問い合わせください。ありがとう!

4

1 に答える 1

0

selectedItemChangedイベントを発生させないドロップダウンリストで同様の問題がありました。IE11にはいくつかのイベントに問題があることがわかるまで、私にとっては何も役に立ちませんでした。多分それはあなたの質問への短い答えです。

于 2013-11-05T14:25:01.193 に答える