Telerik——GridView总结(Winform)
在使用Telerik控件时有很多的方法,属性经常被用到,分享在此总结也便于查看复习。
1.基本属性
GridViewTextBoxColumn col = new GridViewTextBoxColumn(); //表头文字位置 col.HeaderTextAlignment = ContentAlignment.MiddleCenter; //数据文字位置 col.TextAlignment = ContentAlignment.MiddleCenter;
AllowAddNewRow 新建行
AllowDragToGroup 拖动分组
AllowEditRow 编辑行
AllowColumnReorder 拖拽表头排序
EnableGrouping 表头上方显示分组
EnableSorting 排序
ShowRowHeaderColumn 数据行 第一列显示
2.设置表头行高
GridViewHistory.TableElement.TableHeaderHeight = 80;
3.日期时间列 格式化
radGridView1.Columns[0].FormatString = "{0:g}"; //2000-10-10 10:10:50 2000-10-10 10:10
数字、货币格式: 在指定的格式符号后可以指定小数所要显示的位数。例如原来的数据为「1.56」,若格式设定为 {0:N1},则输出为「1.5」。其常用的数值格式如下表所示: 格式字符串 输入 结果 "{0:C}" 12345.6789 $12,345.68 "{0:C}" -12345.6789 ($12,345.68) "{0:D}" 12345 12345 "{0:D8}" 12345 00012345 "{0:E}" 12345.6789 1234568E+004 "{0:E10}" 12345.6789 1.2345678900E+004 "{0:F}" 12345.6789 12345.68 "{0:F0}" 12345.6789 12346 "{0:G}" 12345.6789 12345.6789 "{0:G7}" 123456789 1.234568E8 "{0:N}" 12345.6789 12,345.68 "{0:N4}" 123456789 123,456,789.0000 "Total: {0:C}" 12345.6789 Total: $12345.68 常用的日期时间格式: 格式 说明 输出格式 d 精简日期格式 MM/dd/yyyy D 详细日期格式 dddd, MMMM dd, yyyy f 完整格式 (long date + short time) dddd, MMMM dd, yyyy HH:mm F 完整日期时间格式 (long date + long time) dddd, MMMM dd, yyyy HH:mm:ss g 一般格式 (short date + short time) MM/dd/yyyy HH:mm G 一般格式 (short date + long time) MM/dd/yyyy HH:mm:ss m,M 月日格式 MMMM dd s 适中日期时间格式 yyyy-MM-dd HH:mm:ss t 精简时间格式 HH:mm T 详细时间格式 HH:mm:ss
4.gridview 遇到的问题记录一下
需求:gridview 的一个单元格放两个图片。
方案:定制单元格样式时重写了方法OnBubbleEvent,并事件分发功能,触发点击事件。
遇到问题:点击一次鼠标,触发两次事件。
解决:OnBubbleEvent() 在鼠标点击和弹起时各触发一次,过滤条件中增加鼠标按下事件。
//添加监听
this.dawnGridViewHistory.MasterTemplate.EventDispatcher.AddListener<ActionEventArgs>(ActionEvents.ACTION_EDIT_KEY, this.OnDataItemEdit);
protected override void OnBubbleEvent(Telerik.WinControls.RadElement sender, Telerik.WinControls.RoutedEventArgs args) { if (sender == this.editElement && args.RoutedEvent.EventName == "MouseDownEvent") { // 通过GridView的内部事件分发功能,引发编辑事件 // base.MasterTemplate.EventDispatcher.RaiseEvent<ActionEventArgs>(ActionEvents.ACTION_EDIT_KEY, this, new ActionEventArgs() { Action = ActionEvents.ACTION_EDIT_KEY, }); } }