没有找到合适的产品?
联系客服协助选型:023-68661681
提供3000多款全球软件/控件产品
针对软件研发的各个阶段提供专业培训与技术咨询
根据客户需求提供定制化的软件开发服务
全球知名设计软件,显著提升设计质量
打造以经营为中心,实现生产过程透明化管理
帮助企业合理产能分配,提高资源利用率
快速打造数字化生产线,实现全流程追溯
生产过程精准追溯,满足企业合规要求
以六西格玛为理论基础,实现产品质量全数字化管理
通过大屏电子看板,实现车间透明化管理
对设备进行全生命周期管理,提高设备综合利用率
实现设备数据的实时采集与监控
利用数字化技术提升油气勘探的效率和成功率
钻井计划优化、实时监控和风险评估
提供业务洞察与决策支持实现数据驱动决策
翻译|使用教程|编辑:龚雪|2025-02-12 10:25:53.123|阅读 28 次
概述:本文主要介绍DevExpress WPF Grid控件的未绑定列,欢迎下载最新版组件体验!
# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>
相关链接:
DevExpress WPF拥有120+个控件和库,将帮助您交付满足甚至超出企业需求的高性能业务应用程序。通过DevExpress WPF能创建有着强大互动功能的XAML基础应用程序,这些应用程序专注于当代客户的需求和构建未来新一代支持触摸的解决方案。 无论是Office办公软件的衍伸产品,还是以数据为中心的商业智能产品,都能通过DevExpress WPF控件来实现。
未绑定列未绑定到数据源中的字段,这些列允许您根据绑定列中的值计算值,或显示来自自定义数据源的数据。
DevExpress WPF GridControl中绑定列和未绑定列的功能是相同的,您可以按照与绑定列相同的方式对未绑定列进行排序、分组、显示摘要和筛选。
DevExpress技术交流群11:749942875 欢迎一起进群讨论
1. 向集合添加一个GridColumn对象。
2. 将UnboundDataType属性设置为列应存储的值的类型,GridControl根据该属性值选择列的默认编辑器。要替换编辑器,请使用属性。
3. 为属性分配一个唯一的字段名,字段名不能与另一列的字段名或数据源字段名相匹配。
4. 使用以下技术当中的一个向未绑定列填充数据:
XAML
<Window ... xmlns:dxg="//schemas.devexpress.com/winfx/2008/xaml/grid" xmlns:sys="clr-namespace:System;assembly=mscorlib"> <dxg:GridControl x:Name="grid"> <!-- ... --> <dxg:GridColumn FieldName="Total" UnboundDataType="{x:Type sys:Decimal}" UnboundExpression="[Quantity] * [UnitPrice]"/> </dxg:GridControl>
C#
grid.Columns.Add(new DevExpress.Xpf.Grid.GridColumn() { FieldName = "Total", UnboundDataType = typeof(decimal), UnboundExpression = "[Quantity] * [UnitPrice]" });
VB.NET
grid.Columns.Add(New DevExpress.Xpf.Grid.GridColumn() With { .FieldName = "Total", .UnboundDataType = GetType(Decimal), .UnboundExpression = "[Quantity] * [UnitPrice]" })
您也可以使用/属性来维护一个干净的MVVM模式,并在ViewModel中填充未绑定的列。
XAML
<dxg:GridControl ItemsSource="{Binding Items}" CustomUnboundColumnDataCommand="{Binding UnboundColumnDataCommand}"> <!-- ... --> <dxg:GridColumn FieldName="Total" UnboundDataType="{x:Type sys:Decimal}"/> </dxg:GridControl>
C#
[Command] public void UnboundColumnData(UnboundColumnRowArgs args) { if(args.IsGetData) { var item = (Product)args.Item; args.Value = item.UnitPrice * item.Quantity; } }
VB.NET
<Command> Public Sub UnboundColumnData(ByVal args As UnboundColumnRowArgs) If args.IsGetData Then Dim item = CType(args.Item, Product) args.Value = item.UnitPrice * item.Quantity End If End Sub
在大多数情况下,未绑定列的数据是从自定义数据源获取的,或者根据绑定列的值计算。
如果从自定义数据源检索未绑定数据,则可以对其进行编辑。在用户更改了未绑定列的值之后,应该将该值保存回网格的数据源。要为未绑定列提供数据并将任何更改保存到自定义数据源,请处理 事件。请注意,此事件仅针对未绑定的列引发。
事件参数的属性返回true,将为每个数据行引发事件,从而允许指定未绑定列的值。网格数据源中被处理的行索引由属性返回,应该给属性分配一个值。
事件参数的属性返回true,属性包含应该保存到自定义数据源的修改后的单元格值。
下面的代码示例使用Dictionary创建一个可编辑的未绑定列:
XAML
<dxg:GridControl Name="grid" AutoGenerateColumns="AddNew" EnableSmartColumnsGeneration="True" ItemsSource="{Binding List}" CustomUnboundColumnData="grid_CustomUnboundColumnData"> <dxg:GridControl.Columns> <dxg:GridColumn FieldName="MyUnboundColumn" UnboundDataType="{x:Type sys:String}"/> <!-- ... --> </dxg:GridControl.Columns> </dxg:GridControl>
C#
Dictionary<int, string> unboundData = new Dictionary<int, string>(); unboundData[0] = "MyText"; //... private void grid_CustomUnboundColumnData(object sender, GridColumnDataEventArgs e) { if (e.Column.FieldName == "MyUnboundColumn") { // Populate columns if (e.IsGetData) { if (unboundData.ContainsKey(e.ListSourceRowIndex)) e.Value = unboundData[e.ListSourceRowIndex]; } // Post edited values to the underlying data source if (e.IsSetData && e.Value != null) { unboundData[e.ListSourceRowIndex] = e.Value.ToString(); } } }
VB.NET
Dictionary<int, string> unboundData = new Dictionary<int, string>(); unboundData[0] = "MyText"; ' ... Private Sub grid_CustomUnboundColumnData(ByVal sender As Object, ByVal e As GridColumnDataEventArgs) If e.Column.FieldName = "MyUnboundColumn" Then ' Populate columns If e.IsGetData Then If unboundData.ContainsKey(e.ListSourceRowIndex) Then e.Value = unboundData(e.ListSourceRowIndex) End If ' Post edited values to the underlying data source If e.IsSetData AndAlso e.Value IsNot Nothing Then unboundData(e.ListSourceRowIndex) = e.Value.ToString() End If End If End Sub
慧都科技为国内众多知名企业提供一站式的DevExpress产品中文服务,负责DevExpress控件产品中国区的销售、试用、技术支持,赋能航空航天、金融、医疗等行业客户成功构建企业级应用!欢迎咨询:023-68661681,慧都科技助力企业迈向新高度!
本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@dpuzeg.cn
文章转载自:慧都网本教程演示DevExpress WinForms的Banded Grid View 是如何进行用户自定义的,欢迎下载最新版组件体验!
可视化项目时间线对于有效规划和跟踪至关重要。在本篇教程中,您将学习如何使用 C# 在 Excel 中创建组合图,只需几行代码,即可自动生成动态、美观的组合图。
本文将为大家介绍DevExpress XAF将.NET Aspire集成到Blazor项目中后如何实现数据库依赖,欢迎下载最新版组件体验!
FP3 文件是使用流行的报表生成工具FastReport创建的报表。这种格式广泛用于存储可立即查看的报表数据,这些数据可以轻松共享或保存以供日后分析。但是,要打开和查看此类文件,需要一个特殊的程序——FastReport Viewer。
优秀的界面控件开发包,帮助企业构建卓越应用!
DevExpress DXperience Subscription高性价比的企业级.NET用户界面套包,助力企业创建卓越应用!
DevExpress WPF Subscription高效MVVM开发模式,WPF界面解决方案首选工具,帮助企业实现酷炫动效界面。
服务电话
重庆/ 023-68661681
华东/ 13452821722
华南/ 18100878085
华北/ 17347785263
客户支持
技术支持咨询服务
服务热线:400-700-1020
邮箱:sales@dpuzeg.cn
关注我们
地址 : 重庆市九龙坡区火炬大道69号6幢