如何在wpf中访问数据网格列标题内的文本框?

问题描述 投票:-1回答:1

我是WPF的新手。因为我已经在datagrid列标题中添加了一个文本框列以实现搜索功能。我无法访问项目中我的数据网格内的文本框名称。

我的XAML:

<DataGrid  DataContext="{Binding Details}" Name="g1" ItemsSource="{Binding}"   >   
            <DataGrid.Columns>
               <DataGridTextColumn Binding="{Binding BrokerCode , UpdateSourceTrigger=PropertyChanged}"  HeaderStyle="{StaticResource CenterGridHeaderStyle}"  Header="Broker Code" x:Name="BrokerCode"  Width="100"  >
               <DataGridTextColumn.HeaderTemplate>
                        <DataTemplate>
                            <StackPanel Orientation="Vertical">
                                <Label VerticalAlignment="Center" HorizontalContentAlignment="Center" HorizontalAlignment="Center" Content="Broker Code" />
                                <TextBox x:Name="NameTextBox"  MinWidth="100"  TextChanged="SearchTextBox_TextChanged" Text="{Binding Filter, ElementName=mainwindow, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay }"/>    
                            </StackPanel>
                        </DataTemplate>
                    </DataGridTextColumn.HeaderTemplate>
                </DataGridTextColumn>
</Datagrid>

我的C#:

  SqlConnection con = new SqlConnection();
            con.ConnectionString = 
              ConfigurationManager.ConnectionStrings["connEmployee"].ConnectionString;
               con.Open();           
                SqlCommand cmd = new SqlCommand();
                cmd.CommandText = "select BrokerCode from [SMAFI]";
                cmd.Connection = con;
                SqlDataAdapter adapter1 = new SqlDataAdapter(cmd);
                DataTable dt1 = new DataTable("SMAFI");
                var getdata = adapter1.Fill(dt1);
                List<Details> details = new List<Details>();
                details = (from DataRow row in dt1.Rows
                           select new Details()
                           {
                               BrokerCode = row["BrokerCode"].ToString()                                   
                           }).ToList();
                 g1.ItemsSource = details;
                  details = details.Where(x => 
                 x.BrokerCode.ToLower().StartsWith(NameTextBox.Text.ToLower())).ToList();
                 g1.ItemsSource = details;

我已经在后面的代码中编写了textchange事件,并且我想在C#中访问“ NameTextBox”(文本框的名称)。请帮助我。

wpf filter datagrid controls datagridcolumnheader
1个回答
0
投票

DataGridColumn.Header接受任何种类的内容,甚至包括其他控件。不用DataGridColumn.Header,只需将DataTemplate直接放在列的标题中即可:

TextBox

这将使您可以按名称访问<DataGrid DataContext="{Binding Details}" Name="g1" ItemsSource="{Binding}"> <DataGrid.Columns> <DataGridTextColumn Binding="{Binding BrokerCode , UpdateSourceTrigger=PropertyChanged}" HeaderStyle="{StaticResource CenterGridHeaderStyle}" x:Name="BrokerCode" Width="100"> <DataGridTextColumn.Header> <StackPanel Orientation="Vertical"> <Label VerticalAlignment="Center" HorizontalContentAlignment="Center" HorizontalAlignment="Center" Content="Broker Code" /> <TextBox x:Name="NameTextBox" MinWidth="100" TextChanged="SearchTextBox_TextChanged" Text="{Binding Filter, ElementName=mainwindow, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"/> </StackPanel> </DataGridTextColumn.Header> </DataGridTextColumn> </DataGrid.Columns> </DataGrid> 。注意:只要正确设置TextBox,绑定仍然可以使用DataTemplate方法。

© www.soinside.com 2019 - 2024. All rights reserved.