WPF实现一个表格数据从cs获取动态渲染

  1. xaml代码
xml 复制代码
<Window x:Class="YourNamespace.MainWindow"  xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"  
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"  
        Title="MainWindow" Height="350" Width="525">  
    <Grid>  
        <DataGrid AutoGenerateColumns="False" ItemsSource="{Binding Products}">  
           <DataGrid.Resources>
	         <!--设置表头样式-->
             <Style TargetType="{x:Type DataGridColumnHeader}">
                 <Setter Property="HorizontalContentAlignment" Value="Center"/>
                 <Setter Property="VerticalAlignment" Value="Center"/>
                 <Setter Property="FontSize" Value="16"/>
                 <Setter Property="Padding" Value="0 10"/>
             </Style>
             <!--设置行样式-->
             <Style x:Key="CenteredTextBlockStyle" TargetType="{x:Type TextBlock}">
                  <Setter Property="VerticalAlignment" Value="Center"/>
                  <Setter Property="HorizontalAlignment" Value="Center"/>
                  <Setter Property="FontSize" Value="16"/>
              </Style>
            </DataGrid.Resources>
	    	<DataGrid.Columns>  
		        <DataGridTextColumn Header="Id" Binding="{Binding Id}" />  
		        <!--设置超出自动换行并显示滚动条-->
		        <DataGridTemplateColumn Header="Name" Width="2*">
         <DataGridTemplateColumn.CellTemplate >
            <DataTemplate>
            <ScrollViewer HorizontalScrollBarVisibility="Disabled" VerticalScrollBarVisibility="Auto">
                <TextBlock Text="{Binding Name}" TextWrapping="Wrap" Style="{StaticResource CenteredTextBlockStyle}"/>
            </ScrollViewer>
            </DataTemplate>
          </DataGridTemplateColumn.CellTemplate>
          </DataGridTemplateColumn>
		  <DataGridTextColumn Header="Price" Binding="{Binding Price}" />  
		<DataGridTemplateColumn Header="操作" Width="100">
		  <!--设置表格内的一个按钮-->
        <DataGridTemplateColumn.CellTemplate>
         <DataTemplate>
            <StackPanel Orientation="Horizontal">
                <Button Content="编辑" Cursor="Hand" Click="editButton_Dianji" >
                    <Button.Resources>
                        <Style TargetType="{x:Type Border}">
                            <Setter Property="CornerRadius" Value="5"/>
                        </Style>
                    </Button.Resources>
                </Button>
            </StackPanel>
         </DataTemplate>
        </DataGridTemplateColumn.CellTemplate>
      </DataGridTemplateColumn>
	    	</DataGrid.Columns>  
		</DataGrid>
    </Grid>  
</Window>

2.cs代码

csharp 复制代码
public ObservableCollection<Product> Products { get; set; }  
  
public MainWindow()  
{  
    InitializeComponent();  
    this.DataContext = this; // 设置数据上下文为当前窗口实例 
    // 初始化产品集合  
    Products = new ObservableCollection<Product>  
    {  
        new Product { Id = 1, Name = "Product 1", Price = 10.99M },  
        new Product { Id = 2, Name = "Product 2", Price = 20.99M }  
        // 添加更多产品...  
    };  
}
相关推荐
霍理迪2 小时前
CSS——背景样式以及雪碧图、渐变
前端·css
jump_jump5 小时前
基于 Squoosh WASM 的浏览器端图片转换库
前端·javascript·性能优化
小二·9 小时前
前端监控体系完全指南:从错误捕获到用户行为分析(Vue 3 + Sentry + Web Vitals)
前端·vue.js·sentry
阿珊和她的猫10 小时前
`require` 与 `import` 的区别剖析
前端·webpack
谎言西西里10 小时前
零基础 Coze + 前端 Vue3 边玩边开发:宠物冰球运动员生成器
前端·coze
努力的小郑10 小时前
2025年度总结:当我在 Cursor 里敲下 Tab 的那一刻,我知道时代变了
前端·后端·ai编程
翔云 OCR API10 小时前
发票查验接口详细接收参数说明-C#语言集成完整示例-API高效财税管理方案
开发语言·c#
GIS之路11 小时前
GDAL 实现数据空间查询
前端
OEC小胖胖11 小时前
01|从 Monorepo 到发布产物:React 仓库全景与构建链路
前端·react.js·前端框架
2501_9447114311 小时前
构建 React Todo 应用:组件通信与状态管理的最佳实践
前端·javascript·react.js