首页 > 代码库 > ASPXGridView使用小结
ASPXGridView使用小结
ASPxGridView1.DataSource = dt.defaultView;//指定Grid的数据 ASPxGridView1.DataBind(); //执行绑定 注意,如果查询结果字段有别名,编辑该字段时,UnboundType应设为Object
方式一、展开列标题旁边的过滤清单过滤数据(类似Excel的过滤方式)grid.Settings.ShowHeaderFilterButton = true;过滤清单列出了该列出现的所有数据。还可以自定义过滤清单的内容,用法参阅:http://demos.devexpress.com/ASPxGridViewDemos/Filtering/HeaderFilter.aspx
方式二、在列头显示字段过滤条件输入框 grid.Settings.ShowFilterRow = true; 显示条件判断方式下拉列表grid.Settings.ShowFilterRowMenu = true;
//取值 用e.NewValues[索引]
ASPxGridView1.CancelEdit();//结束编辑状态 e.Cancel = true; bind(); }
getdata(); ASPxGridView1.Caption = "IP为"+GetClientIP()+"的用户,正在查看网银终端更新内容";
}
fangqm.Netbank.Core.groupInfo group = new fangqm.Netbank.Core.groupInfo(); DataTable dt = group.groupSelectAll();//table for (int i = 0; i < dt.Rows.Count; i++) { int id = Convert.ToInt32(dt.Rows[i][0]); string v= dt.Rows[i][1].ToString();
}
汇总计算aspxgridview的所有行求得平均或总和并显示在页脚。
当settings.showfooter属性设置为True,才显示页脚。
aspxgridview的汇总条目是放在totalsummary属性里。设置DisplayFormat例如:总计{0]台终端,
设置FieldName为非绑定字段,SummaryType设为Sum表示计算这一列的和
2、 绑定主从表(IList)
List的元素带有List属性(Category.Products),并且需要以Grid嵌套的方式显示。
1、 选中GridView(gird1),右键菜单选择“编辑模板”—“DetailRow”,页面打开明细数据界面,向DetailRow添加一个新的ASPxGridView (grid2)显示明细数据,可以设定grid2的Columns相关属性。Grid2.SettingsDetail.IsDetailGrid = true 指定grid2作为从表数据表格。
2、 增加grid2 DataBinding事件
Code protected void grid2_DataBinding(object sender, EventArgs e) { DevExpress.Web.ASPxGridView.ASPxGridView grid = sender as DevExpress.Web.ASPxGridView.ASPxGridView; if ((grid != null) && (dict != null)) { int i = (int) grid.GetMasterRowKeyValue();/*取主表记录的Key,主表grid必须设定KeyFieldName*/ if (i >= 0) { grid.DataSource = dict.Products;//通过Key定位数据,指定子表数据源 } } }
3、 右键点击DetailRow,选“结束模板编辑”。修改grid1.SettingsDetail的相关属性
Bool AllowOnlyOneMasterRowExpanded 默认False,是否只允许主表一行展开。True后展开第二行明细记录时,会关闭上次展开的明细记录。
Bool ShowDetailButton 是否显示明细按钮,True显示一个“+”在行首
Bool ShowDetailRow True显示明细数据
4、 过滤数据
方式一、展开列标题旁边的过滤清单过滤数据(类似Excel的过滤方式) grid.Settings.ShowHeaderFilterButton = true;过滤清单列出了该列出现的所有数据。还可以自定义过滤清单的内容,用法参阅:http://demos.devexpress.com/ASPxGridViewDemos/Filtering/HeaderFilter.aspx
方式二、在列头显示字段过滤条件输入框 grid.Settings.ShowFilterRow = true; 显示条件判断方式下拉列表grid.Settings.ShowFilterRowMenu = true;
5、 用户自定义列显示
Grid.SettingCustomizationWindow
Enabled 运行自定义列显示
PopupHorizontalAlign 列编辑窗水平对齐方式
PopupVerticalAlign 列编辑窗垂直对齐方式
通过JavaScript打开列编辑框。
Code <script. type="text/javascript">
<%-- 变更按钮的标题 --%> function UpdateCustomizationWindowValue() { var element = document.getElementById("btnCustWindow"); if(element == null) return; element.value = http://www.mamicode.com/(grid.IsCustomizationWindowVisible() ?"Hide" : "Show") + " Customization Window"; } <%-- 显示自定义列编辑窗--%> function ShowHideCustomizationWindow() { if(grid.IsCustomizationWindowVisible()) grid.HideCustomizationWindow(); else grid.ShowCustomizationWindow(); UpdateCustomizationWindowValue(); } </script> <input id="btnCustWindow" type="button" value="http://www.mamicode.com/Show Customization Window" nclick="ShowHideCustomizationWindow();"/>
<dxwgv:ASPxGridView ID="gird"…………………….> ………………………….. <ClientSideEvents CustomizationWindowCloseUp="function(s, e) { UpdateCustomizationWindowValue(); }" /> </dxwgv:ASPxGridView>
小技巧: AspxGridView在绑定数据的时候,如果数据列的类型是日期型,这时应该用“GridViewDataColumn”而不应该用“GridViewDataTextColumn”,这样的话,数据显示出来的格式就如“1900-01-01",而不是"1900-01-01 0:00:00".
AspxGridView中查找控件不能像GridView中一样用FindControl,而应该用 FindRowCellTemplateControl方法。
应该彻底放弃Response.Write()方法来输出字符中,如果页面中调用了Response.Write方法,会导致AspxGridView的客户端排序功能失去控件,具体表现为:点击排序时,显示loading,然后就没有反应了,一直loading下去,不会完成排序操作。
利用ASPxGridViewExporter导出aspxgridview中的数据时,如果有数据列,虽然我们可以利用 <PropertiesDateEdit DisplayFormatString="{0:yyyy-MM-dd}">
</PropertiesDateEdit>来格式化aspxgridview的日期列显示样式,但是我们却无法控制利用ASPxGridViewExporter导出后的excel文件中的样式,这时,导出的excel文件中,日期列的显示格式为数据库中aspxgridview数据源中日期列的格式。所以如果想控制导出后excel日期列的格式,必须从aspxgridview的数据源下手,在数据源中格式化日期列,就可以达到格式化导出后excel文件日期列格式的目的了 四:导出ASPxGridView的数据 添加一个ASPxGridViewExporter控件到Page,设置GridViewID为需要导出数据的aspxgridview,调用以下方法实现导出。 ASPxGridViewExporter1.WriteXlsToResponse() ASPxGridViewExporter1.WriteCvsToResponse() ASPxGridViewExporter1.WritePdfToResponse() ASPxGridViewExporter1.WriteRtfToResponse() 关于导出EXCEL日期格式,操作EXCEL,设置单元格为相应的格式即可 1.遍历主键列中的所有数据.
List<object> keyValue = http://www.mamicode.com/AspxGridView1.GetSelectedFieldValues("kid");
string str;
foreach(object key in keyValue)
{
str = key.ToString(); } 2.动态选择某一行.
//n为要选择的行数
AspxGridView1.Selection.SetSelection(n,true);
3.获取所有选择行中的数据.这里要注意去这里查看
4.问题:当AspxGridView的单元格中包含超链接按钮时,AspxGridView排序后引起超链接错位.
解决方案:设置超链接按钮的属性 EnableViewState=false;
5.根据某行的数据,动态设置选择复选框不可编辑,及动态设置行背景色.
protected void AspxGridView1_HtmlRowPrepared(object sender,ASPxGridViewTableRowEventArgs e)
{
//判断bomcode是否为空.
if(e.GetValue("bomcode").ToString().Trim() == "")
{
//设置选择复选框不可编辑
e.Row.Cell[0].Enabled = false;
//将背景色设置为浅灰色
e.Row.BackColor = Color.LightGray;
} }
//表中有个链接地址,实现点链接地址下载文件,引用命名空间DevExpress.Web.ASPxGridView; //如果不想动态绑定,只需要设置列的FieldName为链接址址字段,TextField为显示链接名称的字段即可 protected void ASPxGridView1_Init(object sender, EventArgs e) { GridViewDataHyperLinkColumn colLink = new GridViewDataHyperLinkColumn();//实例化一个超链接列 colLink.Caption = "下载吧";//设置列头 colLink.PropertiesHyperLinkEdit.Text = "这是个链接";//显示链接的名称 colLink.PropertiesHyperLinkEdit.TextField = "LinkName";//显示链接名称要绑定的字段 colLink.FieldName = "LinkURL";//该列绑定的字段 colLink.PropertiesHyperLinkEdit.NavigateUrlFormatString="{0}";//链接地址就是该列绑定的字段
colLink.Visible = true; colLink.Width = 200; ASPxGridView1.Columns.Add(colLink);//把该列添加到ASPxGridview
}
//取得当前控件值的集合 直接寻找控件的ID
List <object> keyValues = this.GridViewmethod.GetSelectedFieldValues("F_XXX");//控件的ID
foreach (object key in keyValues)//循环遍历出来
{
}
2.在AspGridView取得某一行
List <object> keyValues = this.GridViewmethod.GetCurrentPageRowValues("F_xxxxx");//F_xxxxx是主键的值
foreach (object key in keyValues)//循环遍历这一行的每一列的数据
{
}
ASPXGridView使用小结