关于<DataGridTextColumn.Header>文本binding不起效果的解决方案

文章讲述了如何在WPF的DataGrid中正确使用DataGridTextColumn的Header中的TextBlock进行数据绑定,重点在于确保DataContext从ViewModel继承,以解决实际开发中遇到的问题。作者提到将页面名称作为参数传递,并展示了正确的XAML代码实现。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

 <DataGrid.Columns>
         <DataGridTextColumn.Header>
             <TextBlock Text="{Binding ElementName=AxisTravel,Path=DataContext.Statax}"/>
         </DataGridTextColumn.Header>
     </DataGridTextColumn>
 </DataGrid.Columns>

在DataGrid下面的列头中定义textblock文本 binding了却没有效果
右键查看控件属性,发现dataContext继承的就是TextBlock并没有从ViewModel中继承
解决方法如下,定义页面名字传参进去:

  <DataGrid.Columns>
     <DataGridTextColumn Binding="{Binding DynMin}">
         <DataGridTextColumn.Header>
             <TextBlock Text="{Binding ElementName=AxisTravel, Path=DataContext.StatMin}"/>
         </DataGridTextColumn.Header>
     </DataGridTextColumn>
 </DataGrid.Columns>
<Window x:Class="FengJing.Views.OtherView.PlantList" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:local="clr-namespace:FengJing.Views.OtherView" mc:Ignorable="d" Title="苗木信息管理" Height="600" Width="1200" WindowStartupLocation="CenterScreen"> <Window.Resources> <!-- 按钮样式 --> <Style TargetType="Button" x:Key="ActionButton"> <Setter Property="Margin" Value="2"/> <Setter Property="Padding" Value="5,2"/> <Setter Property="MinWidth" Value="60"/> </Style> <!-- 搜索框样式 --> <Style TargetType="TextBox" x:Key="SearchBox"> <Setter Property="Margin" Value="5"/> <Setter Property="Padding" Value="5"/> <Setter Property="MinWidth" Value="200"/> </Style> <!-- 数据网格样式 --> <Style TargetType="DataGrid"> <Setter Property="Margin" Value="10"/> <Setter Property="AutoGenerateColumns" Value="False"/> <Setter Property="CanUserAddRows" Value="False"/> <Setter Property="CanUserDeleteRows" Value="False"/> <Setter Property="SelectionMode" Value="Single"/> <Setter Property="IsReadOnly" Value="True"/> <Setter Property="RowHeaderWidth" Value="0"/> <Setter Property="VerticalScrollBarVisibility" Value="Auto"/> <Setter Property="HorizontalScrollBarVisibility" Value="Auto"/> </Style> <!-- 数字列样式 --> <Style TargetType="DataGridTextColumn"> <Setter Property="ElementStyle"> <Setter.Value> <Style TargetType="TextBlock"> <Setter Property="HorizontalAlignment" Value="Right"/> <Setter Property="Margin" Value="0,0,10,0"/> </Style> </Setter.Value> </Setter> </Style> </Window.Resources> <Grid> <Grid.RowDefinitions> <RowDefinition Height="Auto"/> <RowDefinition Height="*"/> <RowDefinition Height="Auto"/> <RowDefinition Height="Auto"/> <!-- 新增:水平滚动条 --> <RowDefinition Height="Auto"/> <!-- 状态栏 --> </Grid.RowDefinitions> <!-- 工具栏 --> <StackPanel Orientation="Horizontal" Margin="10" Grid.Row="0"> <Button Content="添加苗木" Command="{Binding AddPlantCommand}" Style="{StaticResource ActionButton}" Background="#4CAF50" Foreground="White" Click="Button_Click_Create" Height="33.24"/> <Button Content="刷新列表" Command="{Binding RefreshCommand}" Style="{StaticResource ActionButton}" Height="33.24"/> <TextBox Text="{Binding SearchText, UpdateSourceTrigger=PropertyChanged}" Style="{StaticResource SearchBox}" Tag="输入苗木名称搜索..." Height="33.24"/> <Button Content="搜索苗木" Command="{Binding SearchCommand}" Style="{StaticResource ActionButton}" Margin="5,0,0,0" Height="33.24"/> <Button Content="导入苗木列表" Command="{Binding ImportCommand}" Style="{StaticResource ActionButton}" Margin="5,0,0,0" Height="33.24" Background="#2196F3" Foreground="White"/> </StackPanel> <!-- 数据网格 --> <DataGrid x:Name="PlantDataGrid" ItemsSource="{Binding Plants}" Grid.Row="1" SelectedItem="{Binding SelectedPlant}"> <DataGrid.Columns> <DataGridTextColumn Header="序号" Binding="{Binding Id}" Width="60"/> <DataGridTextColumn Header="苗木名称" Binding="{Binding Name}" Width="100"/> <DataGridTextColumn Header="类型" Binding="{Binding Type}" Width="60"/> <DataGridTextColumn Header="颜色" Binding="{Binding Color}" Width="60"/> <DataGridTextColumn Header="单位" Binding="{Binding Unit}" Width="60"/> <DataGridTextColumn Header="适生地区" Binding="{Binding SuitableRegion}" Width="120"/> <DataGridTextColumn Header="生长习性" Binding="{Binding Habit}" Width="120"/> <DataGridTextColumn Header="奈湿奈旱性" Binding="{Binding WetDroughtTolerance}" Width="70"/> <DataGridTextColumn Header="是否海绵类" Binding="{Binding IsSpongePlant}" Width="70"/> <DataGridTextColumn Header="常绿落叶性" Binding="{Binding EvergreenDeciduous}" Width="80"/> <DataGridTextColumn Header="观赏价值" Binding="{Binding OrnamentalValue}" Width="80"/> <DataGridTextColumn Header="色叶期" Binding="{Binding ColorPeriod}" Width="70"/> <DataGridTextColumn Header="胸径/地径(cm)" Binding="{Binding Diameter, StringFormat={}{0:F2}}" Width="100"/> <DataGridTextColumn Header="高度(cm)" Binding="{Binding Height, StringFormat={}{0:F2}}" Width="80"/> <DataGridTextColumn Header="冠幅(cm)" Binding="{Binding CrownWidth, StringFormat={}{0:F2}}" Width="80"/> <DataGridTextColumn Header="信息价(元)" Binding="{Binding Price, StringFormat={}{0:N2}}" Width="100"/> <DataGridTextColumn Header="创建时间" Binding="{Binding CreateAt, StringFormat=yyyy-MM-dd HH:mm:ss}" Width="130"/> <DataGridTextColumn Header="更新时间" Binding="{Binding LastUpdatedAt, StringFormat=yyyy-MM-dd HH:mm:ss}" Width="130"/> <!-- 操作列 --> <DataGridTemplateColumn Header="操作" Width="190"> <DataGridTemplateColumn.CellTemplate> <DataTemplate> <StackPanel Orientation="Horizontal"> <!-- 新增的查看图片按钮 --> <Button Content="查看图片" Command="{Binding DataContext.ViewImageCommand, RelativeSource={RelativeSource AncestorType=DataGrid}}" CommandParameter="{Binding}" Style="{StaticResource ActionButton}" Background="#4CAF50" Foreground="White" Margin="0,0,5,0"/> <Button Content="编辑" Command="{Binding DataContext.EditPlantCommand, RelativeSource={RelativeSource AncestorType=DataGrid}}" CommandParameter="{Binding}" Style="{StaticResource ActionButton}" Background="#2196F3" Foreground="White"/> <Button Content="删除" Command="{Binding DataContext.DeletePlantCommand, RelativeSource={RelativeSource AncestorType=DataGrid}}" CommandParameter="{Binding}" Style="{StaticResource ActionButton}" Background="#F44336" Foreground="White"/> </StackPanel> </DataTemplate> </DataGridTemplateColumn.CellTemplate> </DataGridTemplateColumn> </DataGrid.Columns> </DataGrid> <!-- 分页控制 --> <StackPanel Orientation="Horizontal" HorizontalAlignment="Center" Grid.Row="2" Margin="0,10"> <Button Content="首页" Command="{Binding FirstPageCommand}" Style="{StaticResource ActionButton}"/> <Button Content="上一页" Command="{Binding PreviousPageCommand}" Style="{StaticResource ActionButton}"/> <TextBlock Text="{Binding CurrentPage, StringFormat='第 {0} 页'}" VerticalAlignment="Center" Margin="10,0"/> <Button Content="下一页" Command="{Binding NextPageCommand}" Style="{StaticResource ActionButton}"/> <Button Content="末页" Command="{Binding LastPageCommand}" Style="{StaticResource ActionButton}"/> <TextBlock Text="每页数量:" VerticalAlignment="Center" Margin="10,0,5,0"/> <ComboBox ItemsSource="{Binding PageSizeOptions}" SelectedItem="{Binding PageSize}" Width="80" Margin="0,0,10,0"/> <TextBlock Text="{Binding TotalCount, StringFormat='共 {0} 条记录'}" VerticalAlignment="Center"/> </StackPanel> <!-- 新增:独立水平滚动条 (Grid.Row="3") --> <!--<ScrollBar Grid.Row="3" Orientation="Horizontal" Minimum="0" Maximum="{Binding ScrollableWidth, ElementName=MainDataGrid}" ViewportSize="{Binding ViewportWidth, ElementName=MainDataGrid}" Value="{Binding HorizontalOffset, ElementName=MainDataGrid, Mode=TwoWay}" Height="20" Margin="10,5,10,5" Visibility="{Binding HasHorizontalScroll, ElementName=MainDataGrid, Converter={StaticResource BoolToVisibilityConverter}}"/>--> <!-- 状态栏 --> <StatusBar Grid.Row="2" VerticalAlignment="Bottom"> <StatusBarItem> <TextBlock Text="{Binding StatusMessage}"/> </StatusBarItem> </StatusBar> </Grid> </Window> 搜索苗木改为精确搜索,可根据“苗木名称”、“类型”、“颜色”、“单位”、”适生地区”、“生长习性”、“耐湿耐寒性”、“是否海绵类”、”常绿落叶性”、“观赏价值”、“色叶期”、“胸径/地径(cm)”、“高度(cm)”、“冠幅(cm)”、“信息价(元)”进行精确搜索,且搜索条件可以为一个也可以为多个。根据以上条件写出代码
07-19
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值