WPF Datagrid 动态生成列 并绑定数据

原文:WPF Datagrid 动态生成列 并绑定数据

说的是这里 因为列头是动态加载的 (后台for循环 一会能看到代码)

数据来源于左侧列

左侧列数据源 当然num1 属于临时的dome使用  可以用ObservableCollection集合代表 动态创建属性

WPF 动态生成对象属性 (dynamic)


  1. ObservableCollection<NameList> listName = new ObservableCollection<NameList>();
  2. private ObservableCollection<NameList> GetNameData()
  3. {
  4. listName.Add(new NameList("市川 賞子", "リーダー", "B", 1, "2", "14", "r1", "R5", "T6"));
  5. listName.Add(new NameList("石田", "リーダー", "C", 2, "33", "T4", "r2", "R5", "T6"));
  6. listName.Add(new NameList("安达 鮎美", "リーダー", "C", 3,"3","4","r1","R6","T6"));
  7. return listName;
  8. }
  9. }
  10. public class NameList : INotifyPropertyChanged
  11. {
  12. public event PropertyChangedEventHandler PropertyChanged;
  13. public NameList(string name, string jOb, string class_, int num, string n1, string n2, string n3, string n4, string n5) { Name = name; Class_ = class_; JOb = jOb; Num = num; Num1 = n1; Num2 = n2; Num3 = n3; Num4 = n4; Num5 = n5; }
  14. private string name;
  15. public string Name
  16. {
  17. get { return name; }
  18. set
  19. {
  20. name = value;
  21. if (PropertyChanged != null)
  22. {
  23. PropertyChanged(this, new PropertyChangedEventArgs("Name"));
  24. }
  25. }
  26. }
  27. private int num;
  28. public int Num
  29. {
  30. get { return num; }
  31. set
  32. {
  33. num = value;
  34. if (PropertyChanged != null)
  35. {
  36. PropertyChanged(this, new PropertyChangedEventArgs("Num"));
  37. }
  38. }
  39. }
  40. private string class_;
  41. public string Class_
  42. {
  43. get { return class_; }
  44. set
  45. {
  46. class_ = value;
  47. if (PropertyChanged != null)
  48. {
  49. PropertyChanged(this, new PropertyChangedEventArgs("Class_"));
  50. }
  51. }
  52. }
  53. private string jOb;
  54. public string JOb
  55. {
  56. get { return jOb; }
  57. set
  58. {
  59. jOb = value;
  60. if (PropertyChanged != null)
  61. {
  62. PropertyChanged(this, new PropertyChangedEventArgs("JOb"));
  63. }
  64. }
  65. }
  66. private string num1;
  67. public string Num1
  68. {
  69. get { return num1; }
  70. set { num1 = value;
  71. if (PropertyChanged != null)
  72. {
  73. PropertyChanged(this, new PropertyChangedEventArgs("Num1"));
  74. }
  75. }
  76. }
  77. private string num2;
  78. public string Num2
  79. {
  80. get { return num2; }
  81. set { num2 = value;
  82. if (PropertyChanged != null)
  83. {
  84. PropertyChanged(this, new PropertyChangedEventArgs("Num2"));
  85. }
  86. }
  87. }
  88. private string num3;
  89. public string Num3
  90. {
  91. get { return num3; }
  92. set { num3 = value;
  93. if (PropertyChanged != null)
  94. {
  95. PropertyChanged(this, new PropertyChangedEventArgs("Num3"));
  96. }
  97. }
  98. }
  99. private string num4;
  100. public string Num4
  101. {
  102. get { return num4; }
  103. set { num4 = value;
  104. if (PropertyChanged != null)
  105. {
  106. PropertyChanged(this, new PropertyChangedEventArgs("Num4"));
  107. }
  108. }
  109. }
  110. private string num5;
  111. public string Num5
  112. {
  113. get { return num5; }
  114. set { num5 = value;
  115. if (PropertyChanged != null)
  116. {
  117. PropertyChanged(this, new PropertyChangedEventArgs("Num5"));
  118. }
  119. }
  120. }
  121. }

列数据动态生成 与数据绑定


  1. public MainWindow()
  2. {
  3. InitializeComponent();
  4. addColumn();
  5. dataGrid.ItemsSource = GetNameData();
  6. }
  7. List<string> LS = new List<string>();
  8. public void addColumn()
  9. {
  10. LS.Add("表下カップ綿天竺仮縫い_37s_C_1");
  11. LS.Add("上カップマーキしつけ_28s_C_2");
  12. LS.Add("上下カップ接ぎ_33s_C_3");
  13. LS.Add("上下カップ押え_62s_B_4");
  14. LS.Add("カップ脇しつけ_14s_B_5");
  15. LS.Add("表上カップレース端押さえ_41s_B_6");
  16. for (int i = 0; i < LS.Count; i++)
  17. {
  18. DataGridTextColumn dl = new DataGridTextColumn();
  19. dl.Header=LS[i];
  20. dl.Binding = new Binding("Num" + (i + 1) );
  21. dataGrid.Columns.Add(dl);
  22. }
  23. }

主要是 bingding 这一行

需要知道这俩块怎么做的朋友 可以看连接

WPF (DataGridColumnHeader)实现自义定列头样式 并绑定数据

WPF (DataGridRowHeaderStyle)实现自义定行样式 并绑定数据

原文地址:https://www.cnblogs.com/lonelyxmas/p/12075395.html

时间: 2024-12-14 06:21:28

WPF Datagrid 动态生成列 并绑定数据的相关文章

WPF DataGrid动态生成列的单元格背景色绑定

原文:WPF DataGrid动态生成列的单元格背景色绑定 <DataTrigger Binding="{Binding RelativeSource={RelativeSource Self}, Path=Column.DisplayIndex}" Value="1"> <Setter Property="Background" Value="{Binding RelativeSource={RelativeSour

Wpf DataGrid动态添加列,行数据(二)

这是第二中方法,可直接绑定,我这里只是做出了一种思路,并不是最完美. 这里注意一下,因为我里面引用了MVVMLight,所以可能代码不是复制过去就能用了的. 样式也是,所以复制过去看不是我贴出来的界面这也不奇怪.代码: <Grid> <Grid.ColumnDefinitions> <ColumnDefinition Width="*"/> </Grid.ColumnDefinitions> <Grid.RowDefinitions

datagrid动态生成列并动态赋值

这周接到的任务是动态生成某datagrid的标题,并且要能够根据动态生成的标题来再去数据库中找到相应的值并拼接赋值上去. 项目经理给我的静态页面如下: 左边一列为车型,右边的上面是零件号,下面是固定的,直接循环生成就行,但是数量不一定,需要动态生成.里面的数据是自动加载的. 后台数据库中能够得到的数据大概是这个形式: 这个问题的难点如下: 1.动态生成datagrid的column. 2.将SQL拿出来的数据拼接成前台需要的横行形式,也就是列转行. 先说下解决的思路和方法. 首先是datagri

WPF datagrid 动态增加列

DataGrid动态增加列 <Window x:Class="WpfApplication1.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" Title="MainWindow" Height="

easylui datagrid 动态生成列

function load(sdate) { $.getJSON("workorder/statistics.do", { sdate : sdate+'-01' }, function(resp) { //获取数据源 var columns = new Array(); //定义列集合 var row = resp.rows[0]; //获取首行数据 //根据首行数据创建columns配置 $.each(row, function(i, v) { if (i != "use

如何用js为动态生成的元素绑定事件

今天在开发项目的时候,需要为用js动态生成的元素绑定一个click事件,但是在页面加载之前,这个元素不存在,没法获取这个元素,然后为其添加事件.查阅jquery api 发现可以用on()事件(注意:新版本的jquery已经把live()去除,现在用on()),为动态生产的元素绑定事件,然后触发该事件执行.比如下面一个例子: 假设我们要给div动态添加的span绑定click事件形成如下结果 x //做法如下: ("#choose_result").on("click&quo

Angular如何给动态生成的元素绑定事件

在AngularJS中,操作DOM一般在指令中完成,事件监听机制是在对于已经静态生成的dom绑定事件,而如果在指令中动态生成了DOM节点,动态生成的节点不会被JS事件监听. 举例来说: angular.module('myapp',[]) .directive('myText',function(){ return{ restrict:'A', template:'<div ng-click="hello()">Hi everyone</div>', link:

jQuery对于动态生成的元素绑定无效的问题~~

问题:很多时候发现,对动态生成的元素绑定click事件是无效的- 原因:直接绑定到动态生成的元素是无效的,是因为Jquery扫描文档找出所有的$(‘’)元素,并把函数绑定到每个元素的click事件上,表明是现有页面上存在的元素,动态生成的元素不包括在内. 解决方法:代理或者说是委托on( ),实现原理是事件的冒泡,在指定的祖先元素中注册事件,元素事件触发,传播到这个元素然后进行筛选. 可以在祖先元素中绑定事件,比如div是祖先元素,而新生成的元素都是div的子元素,所以动态生成的元素的事件就可以

动态生成元素动作绑定,jquery 1.9如何实现

1.7后增加了 live()1.9后被移除了 网上说可以用 on() 代替 可以实际在动态生成元素上绑定动作,没效果,求解绝方法(用低版本的jQuery这种方法,求别说..) 答: 之前有老兄回答过类似这个问题,我把他的写法给你贴一下吧: 你应该使用 on 事件进行绑定,这样新插入的元素就可以触发点击事件了.http://api.jquery.com/on/ $(function(){ $("body").on("click", '.a', function(){