您的示例看起来不像 MVVM,但是如果您想在代码中包含数据,请使用依赖属性。
这是 XAML 的示例
<Window x:Class="Test.MainWindow"
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:Test"
mc:Ignorable="d"
Title="MainWindow" Height="350" Width="525"
Name="myWindow">
<Grid>
<ListView ItemsSource="{Binding ElementName=myWindow, Path=DrawingVisualCollection}">
<ListView.View>
<GridView>
<GridViewColumn Header="Name" DisplayMemberBinding="{Binding Path=Name}"></GridViewColumn>
<GridViewColumn Header="Id" DisplayMemberBinding="{Binding Path=Id}"></GridViewColumn>
</GridView>
</ListView.View>
</ListView>
</Grid>
后面的代码是这样的
namespace Test
{
public class DrawingVisualObject : DrawingVisual
{
public int Id { get; set; }
public string Name { get; set; }
public DrawingVisualObject(int id, string name)
{
Id = id;
Name = name;
}
}
/// <summary>
/// Interaction logic for MainWindow.xaml
/// </summary>
public partial class MainWindow : Window
{
public ObservableCollection<DrawingVisualObject> DrawingVisualCollection
{
get { return (ObservableCollection<DrawingVisualObject>)GetValue(DrawingVisualCollectionProperty); }
set { SetValue(DrawingVisualCollectionProperty, value); }
}
// Using a DependencyProperty as the backing store for DrawingVisualCollection. This enables animation, styling, binding, etc...
public static readonly DependencyProperty DrawingVisualCollectionProperty =
DependencyProperty.Register("DrawingVisualCollection", typeof(ObservableCollection<DrawingVisualObject>), typeof(MainWindow), new PropertyMetadata(new ObservableCollection<DrawingVisualObject>()));
public MainWindow()
{
InitializeComponent();
List<DrawingVisualObject> sample = new List<DrawingVisualObject>();
sample.Add(new DrawingVisualObject(1, "Yolo"));
sample.Add(new DrawingVisualObject(2, "Swag"));
this.FillCollection(sample);
}
public void FillCollection(IEnumerable<DrawingVisualObject> objects2fill)
{
this.DrawingVisualCollection.Clear();
foreach(DrawingVisualObject obj in objects2fill)
{
this.DrawingVisualCollection.Add(obj);
}
}
}
}
这应该适合你
请记住:
如果你再次初始化集合,你可能会破坏绑定。我试图在示例方法 FillCollection() 中展示这一点。所以这意味着如果您使用 MVVM,您应该始终将 ObservableCollection 设置为私有集。
我建议您更准确地再次访问 MVVM。要知道视图模型的共同基础是什么,总是好的start!!!