如何绑定到窗口中的私有列表

本文关键字:列表 窗口 何绑定 绑定 | 更新日期: 2023-09-27 18:15:00

我有一个private List<Tuple<string, string, char>> _trasitions的窗口。在同一个窗口中有一个DataGrid称为dataTrans。如何绑定(最好在XAML) _transitionsdataTrans.ItemsSource ?

如何绑定到窗口中的私有列表

您可以在这里看到示例代码:您必须这样做。
1。将列表移动到视图模型类。
2。为该列表公开一个公共属性。
3。将窗口的数据上下文设置为视图模型类的实例。
4。将属性绑定到XAML中数据网格的ItemSource。
示例代码如下

XAML:

<Window x:Class="TestWPFApp.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:local="clr-namespace:TestWPFApp"
        Title="MainWindow" Height="350" Width="525">
    <Grid>
        <DataGrid ItemsSource="{Binding Transitions}" AutoGenerateColumns="False" CanUserAddRows="False">
            <DataGrid.Columns>
                <DataGridTextColumn x:Name="firstColumn" Header="First" Binding="{Binding Path=Item1, Mode= OneWay}"></DataGridTextColumn>
                <DataGridTextColumn x:Name="secondColumn" Header="Second" Binding="{Binding Path=Item2, Mode= OneWay}"></DataGridTextColumn>
                <DataGridTextColumn x:Name="thirdColumn" Header="Third" Binding="{Binding Path=Item3, Mode= OneWay}"></DataGridTextColumn>
            </DataGrid.Columns>
        </DataGrid>
    </Grid>
</Window>

背后的代码:

using System.Windows;
using System.Collections.Generic;
using System.Linq;
using System.Text.RegularExpressions;
using System;
namespace TestWPFApp
{
    /// <summary>
    /// Interaction logic for MainWindow.xaml
    /// </summary>
    public partial class MainWindow : Window
    {
        public MainWindow()
        {
            InitializeComponent();
            this.DataContext = new MainViewModel();
        }
    }
    public class MainViewModel
    {
        private List<Tuple<string, string, char>> _transitions = new List<Tuple<string, string, char>>();
        public MainViewModel()
        {
            Transitions.Add(new Tuple<string,string,char>("First Item 1","Second Item 1",'A'));
            Transitions.Add(new Tuple<string, string, char>("First Item 2", "Second Item 2", 'B'));
            Transitions.Add(new Tuple<string, string, char>("First Item 3", "Second Item 3", 'C'));
            Transitions.Add(new Tuple<string, string, char>("First Item 4", "Second Item 4", 'D'));
        }
        public List<Tuple<string, string, char>> Transitions
        {
            get { return _transitions; }
            set
            {
                _transitions = value;
            }
        }        
    }
}

您必须将集合公开为公共属性以绑定到它。

public List<Tuple<string, string, char>> Transitions
{
    get { return this.transitions };
}

我还建议定义一个类型而不是使用Tuple,如果你想让UI收到集合更改的通知,那么你应该使集合成为ObservableCollection而不是List

如果集合引用改变了,你还需要实现INotifyPropertyChanged并在引用改变时调用PropertyChanged事件(例如在setter中)。

绑定DataGrid,设置ItemsSource属性:

<DataGrid ItemsSource="{Binding Transitions}" ... />

您必须确保DataGrid的数据上下文是视图模型的实例。详见http://wpftutorial.net/DataGrid.html

那不可能。两个原因

  • 只能绑定属性。
  • 属性必须是公共的。

更多信息请查看此处

所以我看到的唯一选择是将您的字段包装在属性devdigital已经发布。