1

3 列のテーブルの値を更新/挿入/表示するためのテンプレート フィールドを備えた ASP.NET 4.5 グリッドビュー コントロールがあります。したがって、更新を処理するために接続された onUpdating イベントがあります。

私の問題は、0、0.0、またはその他の 0 の順列を入力すると、10 進数の列が更新されないことです。正または負の値で正常に動作し、他の表示列は更新されます。また、10 進数フィールドに 0 を指定して新しい行を挿入しても問題はないようです。

どうすればこれを修正できますか?

    <asp:GridView ID="PriceGroupGv" runat="server" AllowPaging="true" AllowSorting="true" DataSourceID="PriceGroupEds" DataKeyNames="Id" AutoGenerateColumns="false"
         ShowHeader="true" ShowHeaderWhenEmpty="false" ShowFooter="true" ItemType="Infrastructure.PricingGroup"
         CssClass="table table-bordered table-condensed table-striped" AlternatingRowStyle-BackColor="GhostWhite" OnRowUpdating="PriceGroupGv_RowUpdating">
        <EmptyDataTemplate>
            <table class="table table-bordered table-condensed table-striped">
                <tr>
                    <th>Name</th>
                    <th>Markup</th>
                    <th></th>
                </tr>
                <tr>
                    <td>
                        <asp:TextBox ID="NameTxt" runat="server" />
                        <asp:RequiredFieldValidator ID="NameRfv" runat="server" ControlToValidate="NameTxt" ValidationGroup="NewRowVg" ForeColor="Red">
                            *</asp:RequiredFieldValidator>
                    </td>
                    <td>
                        <asp:TextBox ID="MarkupTxt" runat="server"/>
                        <asp:RegularExpressionValidator ID="MarkupRxv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="NewRowVg" ValidationExpression="^(-)?\d+(\.\d\d)?$" ForeColor="Red">
                            #.#</asp:RegularExpressionValidator>
                        <asp:RequiredFieldValidator ID="MarkupRfv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="NewRowVg" ForeColor="Red">
                            *</asp:RequiredFieldValidator>
                    </td>
                    <td>
                        <asp:LinkButton ID="AddBtn" runat="server" Text="Add New" OnClick="AddBtn_Click" CommandArgument="EmptyData" CausesValidation="true"
                             ValidationGroup="NewRowVg"/>
                    </td>
                </tr>
            </table>
        </EmptyDataTemplate>
        <Columns>
            <asp:BoundField DataField="Id" Visible="false" />
            <asp:TemplateField HeaderText="Name">
                <ItemTemplate>
                    <asp:Label ID="NameLbl" runat="server" Text="<%# Item.Name %>" />
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="NameTxt" runat="server" Text="<%# Item.Name %>" />
                    <asp:RequiredFieldValidator ID="NameRfv" runat="server" ControlToValidate="NameTxt" ValidationGroup="EditRowVg" ForeColor="Red">
                        *</asp:RequiredFieldValidator>
                </EditItemTemplate>
                <FooterTemplate>
                    <asp:TextBox ID="NameTxt" runat="server" />
                    <asp:RequiredFieldValidator ID="NameRfv" runat="server" ControlToValidate="NameTxt" ValidationGroup="NewRowVg" ForeColor="Red">
                        *</asp:RequiredFieldValidator>
                </FooterTemplate>
            </asp:TemplateField>
            <asp:TemplateField HeaderText="Markup">
                <ItemTemplate>
                    <asp:Label ID="MarkupLbl" runat="server" Text="<%# Item.Markup %>" />
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:TextBox ID="MarkupTxt" runat="server" Text="<%# Item.Markup %>"/>
                    <%--<asp:RangeValidator ID="MarkupRngv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="EditRowVg" Type="Double"
                        MaximumValue="999.9999" MinimumValue="-999.9999" ForeColor="Red">
                        #.##</asp:RangeValidator>
                    <asp:RegularExpressionValidator ID="MarkupRxv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="EditRowVg" ValidationExpression="^(-)?\d+(\.\d\d)?$" ForeColor="Red">
                        #.#</asp:RegularExpressionValidator>--%>
                    <asp:RequiredFieldValidator ID="MarkupRfv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="EditRowVg" ForeColor="Red">
                        *</asp:RequiredFieldValidator>
                </EditItemTemplate>
                <FooterTemplate>
                    <asp:TextBox ID="MarkupTxt" runat="server"/>
                    <asp:RangeValidator ID="MarkupRngv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="NewRowVg"  Type="Double"
                        MaximumValue="999.9999" MinimumValue="-999.9999" ForeColor="Red">
                        #.##</asp:RangeValidator>
                    <%-- <asp:RegularExpressionValidator ID="MarkupRxv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="NewRowVg" 
                        ValidationExpression="^(-)?\d+(\.\d\d)?$" ForeColor="Red">
                        #.#</asp:RegularExpressionValidator>--%>
                    <asp:RequiredFieldValidator ID="MarkupRfv" runat="server" ControlToValidate="MarkupTxt" ValidationGroup="NewRowVg" ForeColor="Red">
                        *</asp:RequiredFieldValidator>
                </FooterTemplate>
            </asp:TemplateField>
            <asp:TemplateField>
                <ItemTemplate>
                    <asp:LinkButton ID="EditBtn" runat="server" CommandName="Edit" Text="Edit" />
                    <asp:LinkButton ID="DeleteBtn" runat="server" CommandName="Delete" Text="Delete" />
                </ItemTemplate>
                <EditItemTemplate>
                    <asp:LinkButton ID="UpdateBtn" runat="server" CommandName="Update" Text="Update" CausesValidation="true" ValidationGroup="EditRowVg" />
                    <asp:LinkButton ID="CancelBtn" runat="server" CommandName="Cancel" Text="Cancel" />
                </EditItemTemplate>
                <FooterTemplate>
                    <asp:LinkButton id="AddBtn" runat="server" Text="Add New" OnClick="AddBtn_Click" CommandArgument="NotEmpty" CausesValidation="true" ValidationGroup="NewRowVg" />
                </FooterTemplate>
            </asp:TemplateField>
        </Columns>
    </asp:GridView>
    <asp:EntityDataSource ID="PriceGroupEds" runat="server" EnableInsert="true" EnableDelete="true" EnableFlattening="false" EnableUpdate="true" EntitySetName="PricingGroups"
        ConnectionString="name=Entities" DefaultContainerName="Entities" />

コード ビハインド:

    protected void PriceGroupGv_RowUpdating(object sender, GridViewUpdateEventArgs e)
    {
        GridViewRow gvr = (sender as GridView).Rows[e.RowIndex];
        e.NewValues["Name"] = (gvr.FindControl("NameTxt") as TextBox).Text;
        e.NewValues["Markup"] = Decimal.Parse((gvr.FindControl("MarkupTxt") as TextBox).Text);

        PriceGroupGv.DataBind();
    }// end event
4

1 に答える 1

2

解決済み - データベースとモデルでマークアップ列を Nullable にしました。また、タイプを db で Float に、モデルで Double に変更しましたが、最終的に機能するようになったのは、nullable プロパティを持つことでした。

他の誰かがより良い解決策を持っている場合は、他の回答を歓迎します。

于 2013-10-02T19:00:32.897 に答える