2017-02-10 70 views
0

我用的DevExpress Asp.Net控制工作,在GridView的EditTempalte必須添加複選框綁定複選框,必須綁定複選框檢查,並與數據庫列屬性和新項目插入默認選中取消。如何ASPxGridView EditItemTemplate中

這裏我的代碼。

<dx:ASPxGridView ID="ASPxGridView3" runat="server" AutoGenerateColumns="False" DataSourceID="SqlDataSource3" 
       KeyFieldName="UniqueID" Theme="Default"> 
    <SettingsSearchPanel Visible="True" /> 
    <Columns> 
     <dx:GridViewCommandColumn ShowDeleteButton="True" ShowEditButton="True" ShowInCustomizationForm="True" 
      ShowNewButtonInHeader="True" VisibleIndex="0"> 
     </dx:GridViewCommandColumn> 
     <dx:GridViewDataTextColumn FieldName="UniqueID" ReadOnly="True" ShowInCustomizationForm="True" 
      Visible="False" VisibleIndex="1"> 
     </dx:GridViewDataTextColumn> 
     <dx:GridViewDataTextColumn FieldName="ResourceID" ShowInCustomizationForm="True" Visible="False" 
      VisibleIndex="2" ReadOnly="True"> 
      <EditFormSettings Visible="False" /> 
     </dx:GridViewDataTextColumn> 
     <dx:GridViewDataTextColumn FieldName="ResourceName" ShowInCustomizationForm="True" VisibleIndex="3"> 
     </dx:GridViewDataTextColumn> 
     <dx:GridViewDataTextColumn FieldName="Color" ShowInCustomizationForm="True" Visible="False" VisibleIndex="4"> 
      <EditFormSettings Visible="False" /> 
     </dx:GridViewDataTextColumn> 
     <dx:GridViewDataTextColumn FieldName="CustomField1" ShowInCustomizationForm="True" Visible="False" VisibleIndex="5"> 
      <EditFormSettings Visible="False" /> 
     </dx:GridViewDataTextColumn> 
     <dx:GridViewDataTextColumn FieldName="category_ClientID" ShowInCustomizationForm="True" 
      VisibleIndex="6" Visible="False"> 
     </dx:GridViewDataTextColumn> 
     <dx:GridViewDataTextColumn FieldName="IsAvailable" PropertiesTextEdit-NullDisplayText="true" 
      ShowInCustomizationForm="True" VisibleIndex="7"> 
      **<EditItemTemplate> 
       <dx:ASPxCheckBox ID="chkIsAvailableEdit" runat="server" Checked="true" Style="margin-left: 18px" 
        CheckState="Checked" Cursor="pointer" EnableDefaultAppearance="False" 
        EnableTheming="False"> 
        <CheckedImage Height="26px" Url="~/images/switchon.png" Width="70px"> 
        </CheckedImage> 
        <UncheckedImage Height="26px" Url="~/images/switchoff.png" Width="70px"> 
        </UncheckedImage> 
        <GrayedImage Url="~/images/switchoff.png"> 
        </GrayedImage> 
       </dx:ASPxCheckBox> 
      </EditItemTemplate>** 
     </dx:GridViewDataTextColumn> 
    </Columns> 
</dx:ASPxGridView> 
<asp:SqlDataSource ID="SqlDataSource3" runat="server" ConnectionString="<%$ ConnectionStrings:NCompassWebsiteConnectionString %>" 
    DeleteCommand="DELETE FROM [SchResources] WHERE [UniqueID] = @UniqueID" 
    InsertCommand="INSERT INTO [SchResources] ([ResourceID], [ResourceName], [Color], [CustomField1], [category_ClientID], 
      [IsAvailable]) VALUES (@ResourceID, @ResourceName, @Color, @CustomField1, @category_ClientID, @IsAvailable)" 
    SelectCommand="SELECT * FROM [SchResources] WHERE ([category_ClientID] = @category_ClientID)" 
    UpdateCommand="UPDATE [SchResources] SET [ResourceID] = @ResourceID, [ResourceName] = @ResourceName, [Color] = @Color, 
      [CustomField1] = @CustomField1, [category_ClientID] = @category_ClientID, [IsAvailable] = @IsAvailable WHERE [UniqueID] = @UniqueID"> 
    <DeleteParameters> 
     <asp:Parameter Name="UniqueID" Type="Int32" /> 
    </DeleteParameters> 
    <InsertParameters> 
     <asp:Parameter Name="ResourceID" Type="Int32" /> 
     <asp:Parameter Name="ResourceName" Type="String" /> 
     <asp:Parameter Name="Color" Type="Int32" /> 

     <asp:Parameter Name="CustomField1" Type="String" /> 
     <asp:SessionParameter Name="category_ClientID" SessionField="ClientID" Type="String" /> 
     <asp:Parameter Name="IsAvailable" Type="String" /> 
    </InsertParameters> 
    <SelectParameters> 
     <asp:SessionParameter Name="category_ClientID" SessionField="ClientID" Type="String" /> 
     <%--<asp:Parameter DefaultValue="62" Name="category_ClientID" Type="String" />--%> 
    </SelectParameters> 
    <UpdateParameters> 
     <asp:Parameter Name="ResourceID" Type="Int32" /> 
     <asp:Parameter Name="ResourceName" Type="String" /> 
     <asp:Parameter Name="Color" Type="Int32" /> 

     <asp:Parameter Name="CustomField1" Type="String" /> 
     <asp:SessionParameter Name="category_ClientID" SessionField="ClientID" Type="String" /> 
     <asp:Parameter Name="IsAvailable" Type="String" /> 
     <asp:Parameter Name="UniqueID" Type="Int32" /> 
    </UpdateParameters> 
</asp:SqlDataSource> 
+0

什麼錯誤? – jambonick

+0

你爲什麼不聯繫的DevExpress支持直接? – Mikhail

回答

1

只需使用內置GridViewDataCheckColumn(專門用於顯示/編輯布爾值),而不是GridViewDataTextColumn(默認值)之一:

<%-- 
<dx:GridViewDataTextColumn FieldName="IsAvailable"> 
</dx:GridViewDataTextColumn 
--%> 

<dx:GridViewDataCheckColumn FieldName="IsAvailable"> 
</dx:GridViewDataCheckColumn 

檢查this演示。

或者,使用標準的雙向綁定表達式(Bind方法),以提供必要的行的字段名綁定ASPxCheckBox:

<dx:GridViewDataTextColumn FieldName="IsAvailable"> 
    <EditItemTemplate> 
     <dx:ASPxCheckBox ID="chkIsAvailableEdit" ... Value='<%#Bind("IsAvailable")'> 
     </dx:ASPxCheckBox> 
    </EditItemTemplate> 
</dx:GridViewDataTextColumn> 

檢查this演示。

相關問題