怎么选择DataTemplate中的TextBox

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了怎么选择DataTemplate中的TextBox相关的知识,希望对你有一定的参考价值。

我创建了个listbox,使用了一个DataTemplate,里面包含一个Textblock和一个textboxtextbox是默认隐藏的这是xaml:<ListBox> <ListBox.ItemTemplate> <DataTemplate> <Canvas Width="460" Height="60" Background="StaticResource PhoneAccentBrush"> <TextBlock Text="Binding data" FontSize="30" Margin="10,10,10,0"/> <TextBox Height="60" Width="460" Visibility="Collapsed"/> </Canvas> </DataTemplate> </ListBox.ItemTemplate></ListBox>我想实现的效果是,按下textblock 隐藏textblock,同时显示textboxcode behind:\private void TextBlock_Tap(object sender, GestureEventArgs e) TextBlock.Visibilty = Visibility.Collapsed; TextBox.Visibilty = Visibility.Visible; 但是很明显 selector 不对,谁能告诉我怎么选择Data Template里的textblock和textbox?

参考技术A 不能直接访问,试试这个:<ListBox x:Name="MyListBox"> <ListBox.ItemTemplate> <DataTemplate> <Canvas Width="460" Height="60" Background="StaticResource PhoneAccentBrush"> <TextBlock x:Name="MyTextBlock" Text="Binding data" FontSize="30" Margin="10,10,10,0" Tap="MyTextBlock_Tap" /> <TextBox x:Name="MyTextBox" Height="60" Width="460" Visibility="Collapsed"/> </Canvas> </DataTemplate> </ListBox.ItemTemplate></ListBox>private void MyTextBlock_Tap(object sender, GestureEventArgs e) var elem = (FrameworkElement)sender; var myTextBlock = (TextBlock)elem.FindName("MyTextBlock"); var myTextBox = (TextBox)elem.FindName("MyTextBox"); myTextBlock.Visibility = Visibility.Collapsed; myTextBox.Visibility = Visibility.Visible; 参考技术B 不能直接访问,试试这个: private void MyTextBlock_Tap(object sender, GestureEventArgs e) var elem = (FrameworkElement)sender; var myTextBlock = (TextBlock)elem.FindName("MyTextBlock"); var myTextBox = (TextBox)elem.FindName("MyTextBox"); myTextBlock.Visibility = Visibility.Collapsed; myTextBox.Visibility = Visibility.Visible;

带有 DataTemplate 的 ListBox 识别 SelectedItem

【中文标题】带有 DataTemplate 的 ListBox 识别 SelectedItem【英文标题】:ListBox with DataTemplate recognize SelectedItem 【发布时间】:2018-01-07 10:49:06 【问题描述】:

我有一个ListBox 和一个简单的DataTemplate、一个CheckBox 和一个TextBox。 如果用户检查了CheckBox,我想得到这个更改的项目,比如ListBox 的属性SelectedItem

我如何从List2 获取元素,它已经改变了?

MyListItem:

public class MyListItem2 : ReactiveObject


    private string _name;
    public string Name
    
        get  return _name; 
        set
        
            this.RaiseAndSetIfChanged(ref _name, value, "Name");
        
    
    private bool _isMarked;
    public bool IsMarked
    
        get  return _isMarked; 
        set
        
            this.RaiseAndSetIfChanged(ref _isMarked, value, "IsMarked");
        
    

查看:

<Window xmlns="https://github.com/avaloniaui"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="clr-namespace:DataTemplate.Views.MainWindow"
        xmlns:viewsmodels="clr-namespace:DataTemplate.ViewModels;assembly=DataTemplate"
        xmlns:dt="clr-namespace:DataTemplate;assembly=DataTemplate"
        Title="DataTemplate" Width="700">
<Window.DataContext>
  <viewsmodels:MainWindowViewModel />
</Window.DataContext>

<Grid ColumnDefinitions="250">
  <ListBox Grid.Column="1" Items="Binding List2">
    <ListBox.ItemTemplate>
      <DataTemplate DataType="dt:MyListItem2">
        <Grid ColumnDefinitions="50*,50*">              
          <CheckBox Grid.Column="0" Content="Mark" IsChecked="Binding IsMarked"/>  
          <TextBox Grid.Column="1" Text="Binding Name"/>  
        </Grid>
      </DataTemplate>
    </ListBox.ItemTemplate>
  </ListBox>
</Grid>

视图模型:

public class MainWindowViewModel : ReactiveObject

    public ObservableCollection<MyListItem2> List2  get; set;     

    public MainWindowViewModel()
    
        List2 = new ObservableCollection<MyListItem2>();
        Random rand = new Random();

        for (int i = 0; i < rand.Next(1, 20); i++)
        
            MyListItem2 mli = new MyListItem2();
            mli.Name = "ListItem" + i;
            mli.IsMarked = false;
            mli.PropertyChanged += ItemChanged; 
            List2.Add(mli);
        
    
    private void ItemChanged(object sender, PropertyChangedEventArgs e)
                
        var item = sender as MyListItem2;
        Console.WriteLine(string.Format("changed: 0 1", item.Name, item.IsMarked));            
    

【问题讨论】:

【参考方案1】:

我可以看到两种方式:

由于您使用的是 MVVM,因此请在 MyListItem2 类 (Microsoft Reference on INotifyPropertyChanged implementation) 上实现 INotifyPropertyChanged 接口。在设置/更改 IsMarked 值时引发属性更改事件,然后连接到项目的 PropertyChanged 事件处理程序以确定何时更改。 .或

如果您有代码隐藏,请在 XAML 中的复选框本身上添加“选中”和/或“未选中”事件处理程序。如下所示。

CheckBox Grid.Column="0" Content="Mark" IsChecked="Binding IsMarked"/> Checked="IsMarked_Checked"

代码隐藏

public void IsMarked_Checked(object sender, RoutedEventArgs e)

    var ck = sender As Checkbox;

    if (ck == null) 
    
         return;
    

    // do whatever you need to here using the datacontext of the Checkbox

【讨论】:

对不起,我更新了这个问题。请注意,它是 .net 核心和 AvaloniaUI。 我接受你的第一点,这很有效。我只需要将 PropertyChanged 事件路由到我的 ViewModel。我更新了问题中的代码。【参考方案2】:

如果您想知道用户何时选中/取消选中复选框,则需要从复选框触发事件。

使用这样的东西:

private void MyCheckBox_Checked(object sender, RoutedEventArgs e)

    //check IsChecked of MyCheckBox here

【讨论】:

对不起,我更新了这个问题。请注意,它是 .net 核心和 AvaloniaUI【参考方案3】:

尝试设置绑定模式:

SelectedItem="Binding SelectedItem, Mode=TwoWay"

【讨论】:

我认为棘手的部分是,当我更改文本或复选框时,SelectedItem 并没有改变。

以上是关于怎么选择DataTemplate中的TextBox的主要内容,如果未能解决你的问题,请参考以下文章

从 DataTemplate 中绑定到 TabItem 标头

wpf DataGrid 如何获取DataGridTemplateColumn.CellTemplate 中的TextBox的Text值

如何使用 DataTemplate 访问列表框中的特定项目?

如何在 XAML (Silverlight) 中以编程方式设置 TextBox 文本

怎么把一个窗体中的值传到另一个窗体中的textbox中

C#怎么把子窗体中的comboBox1的值能够传到父窗体的toolStrip组件中的textbox中去么?能的话代码怎么写