如何使用编辑模板在ASPxGridView中进行新增修改(除去常规的gridviw模板编辑外)...

aspgridview模板编辑效果图:

模板编辑效果图

//前端代码:(核心: <Templates><EditForm>.....中间可用栅格样式布局等(随意)...</Templates></EditForm>)

//其中文本控件赋值为:

<dx:ASPxSpinEdit ID="SE_BEGINAREA" runat="server" Number='<%# Eval("BEGINAREA") !=null ? decimal.Parse(Eval("BEGINAREA").ToString()) : 0%>' MinValue="0" NumberType="Float" Width="100%">
</dx:ASPxSpinEdit>

 

 

<dx:ASPxGridView ID="ASPxGridView" KeyFieldName="TPUSHMONEY_ID" runat="server" ClientInstanceName="grid" Theme="Mulberry"
AutoGenerateColumns="False" Width="100%"
OnRowInserting="ASPxGridView_RowInserting"
OnRowUpdating="ASPxGridView_RowUpdating">
<ClientSideEvents EndCallback="grid_EndCallback" />
<SettingsText EmptyDataRow="暂无数据" />
<Styles>
<%--<AlternatingRow Enabled="True" />
<Header HorizontalAlign="Center" />
<CommandColumn Spacing="10px" Wrap="False" />--%>

<Table CssClass="tw-dataTable"></Table>
<Header CssClass="tw-dtheader" HorizontalAlign="Center"></Header>

<CommandColumn CssClass="tw-commandColumn"></CommandColumn>
<CommandColumnItem CssClass="tw-commandColumnBtn"></CommandColumnItem>
<FocusedRow CssClass="tw-focusRow"></FocusedRow>
</Styles>
<Settings GridLines="Horizontal" />
<SettingsPager PageSize="10" />
<SettingsBehavior AllowFocusedRow="True" />
<SettingsEditing Mode="PopupEditForm">
</SettingsEditing>
<SettingsPopup>
<%--<CustomizationWindow HorizontalAlign="WindowCenter" VerticalAlign="WindowCenter" />--%>
<EditForm Modal="true" HorizontalAlign="WindowCenter" VerticalAlign="WindowCenter" />
<%-- <HeaderFilter ResizingMode="Postponed" />--%>
</SettingsPopup>
<Columns>
<dx:GridViewDataTextColumn Caption="序号" VisibleIndex="1" Width="100px">
<EditFormSettings Visible="False" />
<CellStyle HorizontalAlign="Center"></CellStyle>
<DataItemTemplate>
<dx:ASPxLabel ID="L_rowid_1" runat="server" Text='<%# Container.ItemIndex + 1 %>'>
</dx:ASPxLabel>
</DataItemTemplate>
</dx:GridViewDataTextColumn>
<dx:GridViewDataColumn FieldName="BEGINAREA" Caption="交易金额区间(起始)" VisibleIndex="2" Width="50px"></dx:GridViewDataColumn>
<dx:GridViewDataColumn FieldName="ENDAREA" Caption="交易金额区间(结束)" VisibleIndex="3" Width="50px"></dx:GridViewDataColumn>
<dx:GridViewDataColumn FieldName="PUSHMONEY" Caption="收取佣金(元/单笔)" VisibleIndex="4" Width="50px"></dx:GridViewDataColumn>
<dx:GridViewDataComboBoxColumn FieldName="GETISFLAG" Caption="是否返回佣金" VisibleIndex="5" Width="30px">
<PropertiesComboBox>
<Items>
<dx:ListEditItem Text="不返回" Value="0" />
<dx:ListEditItem Text="返回" Value="1" />
</Items>
</PropertiesComboBox>
</dx:GridViewDataComboBoxColumn>
<dx:GridViewDataColumn FieldName="PUSHEXPRESS" Caption="返回佣金公式" VisibleIndex="6" ></dx:GridViewDataColumn>
<%--<dx:GridViewDataColumn FieldName="ISVALID" Caption="是否有效" VisibleIndex="7" Width="5px"></dx:GridViewDataColumn>--%>
<dx:GridViewDataCheckColumn FieldName="ISVALID" Caption="是否有效" VisibleIndex="7" Width="5px"></dx:GridViewDataCheckColumn>
<dx:GridViewDataColumn FieldName="TREMARK" Caption="备注" VisibleIndex="8" Visible="false" Width="5px"></dx:GridViewDataColumn>
<dx:GridViewCommandColumn ShowEditButton="true" ShowInCustomizationForm="true" ShowNewButtonInHeader="True" VisibleIndex="9" Width="20px" >
<EditButton Text="修 改"></EditButton>
<%--<NewButton Text ="新 增" >
<Image SpriteProperties-CssClass="btn btn-xs btn-success" Width="100%">

</Image>

</NewButton>--%>
<%-- <EditButton Text="修改"></EditButton>
<UpdateButton Text="确认"></UpdateButton>
<CancelButton Text="取消"></CancelButton>--%>
</dx:GridViewCommandColumn>
</Columns>
<Templates>

<EditForm>
<div class="container-fluid" style="padding-bottom: 20px;">
<div class="row">
<div class="col-sm-12">
<hr />
</div>
<div class="col-sm-6">

<div class="form-group">
<label>交易金额区间(起始)</label>
<dx:ASPxSpinEdit ID="SE_BEGINAREA" runat="server" Number='<%# Eval("BEGINAREA") !=null ? decimal.Parse(Eval("BEGINAREA").ToString()) : 0%>' MinValue="0" NumberType="Float" Width="100%">
</dx:ASPxSpinEdit>
</div>
</div>
<div class="col-sm-6">
<div class="form-group">
<label>交易金额区间(结束)</label>
<dx:ASPxSpinEdit ID="SE_ENDAREA" runat="server" Number='<%# Eval("ENDAREA") !=null ? decimal.Parse(Eval("ENDAREA").ToString()) : 0%>' MinValue="0" NumberType="Float" Width="100%">
</dx:ASPxSpinEdit>
</div>
</div>
<div class="col-sm-12">
<div class="form-group">
<label>收取佣金(元/单笔)</label>
<dx:ASPxSpinEdit ID="SE_PUSHMONEY" runat="server" Number='<%# Eval("PUSHMONEY") !=null ? decimal.Parse(Eval("PUSHMONEY").ToString()) : 0%>' MinValue="0" NumberType="Float" Width="100%">
</dx:ASPxSpinEdit>
</div>
</div>
<div class="col-sm-8">
<div class="form-group">
<label>是否返回佣金</label>
<dx:ASPxComboBox ID="CB_GETISFLAG" runat="server" ValueType="System.String" Width="100%" SelectedIndex='<%# Eval("GETISFLAG") != null? Eval("GETISFLAG").ToString() == "1" ? 1 : 0 : 0%>'>
<Items>
<dx:ListEditItem Text="不返回" Value="0" />
<dx:ListEditItem Text="返回" Value="1" />
</Items>
</dx:ASPxComboBox>
</div>
</div>
<div class="col-sm-4">
<label></label>
<dx:ASPxCheckBox ID="CHEKB_ISVALID" runat="server" Width="100%" Text="是否有效" Checked='<%# Eval("ISVALID") != null ? Eval("ISVALID").ToString() == "1" ? true : false : true %>'>
</dx:ASPxCheckBox>
</div>
<div class="col-sm-12">
<div class="form-group">
<label>返回佣金公式</label>
<dx:ASPxMemo ID="TXT_PUSHEXPRESS" runat="server" Text='<%# Eval("PUSHEXPRESS")%>' Width="100%" Height="72px">
</dx:ASPxMemo>
</div>
<div class="form-group">
<label>备注</label>
<dx:ASPxMemo ID="TXT_TREMARK" runat="server" Text='<%# Eval("TREMARK")%>' Width="100%" Height="72px">
</dx:ASPxMemo>
</div>
</div>
<div class="col-sm-12">
<hr />
</div>

<div class="col-sm-3 col-sm-offset-2">
<%--<dx:ASPxGridViewTemplateReplacement ID="UpdateButton" ReplacementType="EditFormUpdateButton"
runat="server">

</dx:ASPxGridViewTemplateReplacement>--%>
<dx:ASPxButton ID="UpdateButton" runat="server" Text="更 新" CssClass="btn-success" Width="100%" AutoPostBack="false">
<ClientSideEvents Click="function(s,e){grid.UpdateEdit();}"></ClientSideEvents>
</dx:ASPxButton>
</div>
<div class="col-sm-3 col-sm-offset-2">
<%-- <dx:ASPxGridViewTemplateReplacement ID="CancelButton" ReplacementType="EditFormCancelButton"
runat="server"></dx:ASPxGridViewTemplateReplacement>--%>
<dx:ASPxButton ID="CancelButton" runat="server" Text="取 消" CssClass="btn-default" Width="100%" AutoPostBack="false">
<ClientSideEvents Click="function(s,e){grid.CancelEdit();}"></ClientSideEvents>
</dx:ASPxButton>
</div>
</div>
</div>
</EditForm>
</Templates>
</dx:ASPxGridView>

 

//后台代码(实现数据绑定操作及赋值等)

第一步:首先要定义一个自定义的方法-----用于获取到gridview中的编辑模板中的需要修改新增的控件名( 控件的id),方法如下

protected object GetControlValue(string controlname,ASPxEditBase editBase)
{
editBase = ASPxGridView.FindEditFormTemplateControl(controlname) as ASPxEditBase;
return editBase.Value;
}

获取编辑模板中的控件名:获取编辑模板中的控件名

第二步:写新增、修改的方法(写在gridview自带的新增修改事件中),就以修改为例:

protected void ASPxGridView_RowUpdating(object sender, DevExpress.Web.Data.ASPxDataUpdatingEventArgs e)
{
int TPUSHMONEY_ID = Convert.ToInt32(e.Keys["TPUSHMONEY_ID"].ToString()); //拥金配置表id

//ASPxSpinEdit SE_BEGINAREA = ASPxGridView.FindEditFormTemplateControl("SE_BEGINAREA") as ASPxSpinEdit;
//Convert.ToDecimal(e.NewValues["BEGINAREA"] == null ? "" : e.NewValues["BEGINAREA"].ToString());
decimal BEGINAREA = Convert.ToDecimal(GetControlValue("SE_BEGINAREA", spinEdit)); //交易金额区间(起始)
decimal ENDAREA = Convert.ToDecimal(GetControlValue("SE_ENDAREA", spinEdit)); //交易金额区间(结束)
decimal PUSHMONEY = Convert.ToDecimal(GetControlValue("SE_PUSHMONEY", spinEdit)); //收取佣金(元/单笔)
int GETISFLAG = Convert.ToInt32(GetControlValue("CB_GETISFLAG", comboBox)); //是否返回佣金
String PUSHEXPRESS = GetControlValue("TXT_PUSHEXPRESS", txtMemo).ToString(); //返回佣金公式
int ISVALID = Convert.ToInt32(GetControlValue("CHEKB_ISVALID", checkBox)); //是否有效
String TREMARK = GetControlValue("TXT_TREMARK", txtMemo).ToString(); //备注
if (plateformmanagebll.UpdateCommSetting(TPUSHMONEY_ID,BEGINAREA, ENDAREA, PUSHMONEY, GETISFLAG, PUSHEXPRESS, ISVALID, TREMARK) > 0)
{
SpanHelper.AspxGridViewEdit(sender, 1, "恭喜!佣金公式修改成功!");
e.Cancel = true;
this.ASPxGridView.CancelEdit();
showPlatmoneyList();
}
}

模板编辑修改事件代码图:模板编辑修改事件代码图

转载于:https://www.cnblogs.com/dfxyw/p/5080068.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值