正确地将ItemsSource列表绑定到Linq表

时间:2013-06-24 01:05:57

标签: linq binding windows-phone-7.1 datacontext itemssource

我正在尝试将列表框的项源绑定到Linq表,就像通常将ObservableCollection绑定到它一样。

我希望我的列表在删除,添加和更改项目时使用表格进行更新。

我已经在表所包含的类上实现了INotifyPropertyChanged。这使列表更新了我的项目所包含的属性,但是,为了在添加或删除项目时更新列表,我必须以编程方式重新绑定ItemsSource以强制更新列表。

数据背景

public class LocalDatabase : DataContext
{
    public static string connectionString = "Data Source=isostore:/Database.sdf";

    public LocalDatabase() : base(connectionString) { }

    public Table<Connection> Connections;
}

表对象

[Table]
public class Connection : INotifyPropertyChanged
{
    private string name;
    private string ip;
    private ushort port;

    [Column(IsPrimaryKey=true, IsDbGenerated=true)]
    public int ID { get; set; }
    [Column]
    public string Name { get { return name; } set { name = value; NotifyPropertyChanged("Name"); } }
    [Column]
    public string IP { get { return ip; } set { ip = value; NotifyPropertyChanged("IP"); } }
    [Column]
    public ushort Port { get { return port; } set { port = value; NotifyPropertyChanged("Port"); } }

    public event PropertyChangedEventHandler PropertyChanged;
    private void NotifyPropertyChanged(String propertyName)
    {
        PropertyChangedEventHandler handler = PropertyChanged;
        if (null != handler)
        {
            handler(this, new PropertyChangedEventArgs(propertyName));
        }
    }
}

目标列表

        <ListBox Name="listBoxConnections" SelectionChanged="listBoxConnections_SelectionChanged">
            <ListBox.ItemTemplate>
                <DataTemplate>
                    <StackPanel Margin="0,0,0,17" Width="432" Height="78">
                        <toolkit:ContextMenuService.ContextMenu>
                            <toolkit:ContextMenu>
                                <toolkit:MenuItem Header="Edit" Click="ConnectionEdit" Tag="{Binding ID}" />
                                <toolkit:MenuItem Header="Delete" Click="ConnectionDelete" Tag="{Binding ID}" />
                            </toolkit:ContextMenu>
                        </toolkit:ContextMenuService.ContextMenu>
                        <TextBlock Text="{Binding Name}" TextWrapping="Wrap" Style="{StaticResource PhoneTextExtraLargeStyle}"/>
                        <StackPanel Orientation="Horizontal" Margin="12,-6,12,0">
                            <TextBlock Text="{Binding IP}" Style="{StaticResource PhoneTextSubtleStyle}" Margin="0" />
                            <TextBlock Text=":" Margin="2,0,2,0" />
                            <TextBlock Text="{Binding Port}" Style="{StaticResource PhoneTextSubtleStyle}" Margin="0" />
                        </StackPanel>
                    </StackPanel>
                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>

当前绑定方法

    public LocalDatabase Database { get; set; }

    public MainPage()
    {
        InitializeComponent();

        Database = new LocalDatabase();
        if (!Database.DatabaseExists()) Database.CreateDatabase();

        listBoxConnections.ItemsSource = Database.Connections;
        DataContext = this;
    }

恐怕某处可能有重复,但我一直在寻找最近2天,并没有找到任何解决方案或类似问题。可能使用错误的查询。

因此,总而言之,我想知道将表绑定到列表的正确方法,更新项目删除或添加,以及所有这些好东西。

我正在使用Windows Phone 7.1

1 个答案:

答案 0 :(得分:0)

最好的方法是将您的UI代码与数据库代码分开。让ListBox绑定到ObservableCollection,而不是Table。

试试看: http://msdn.microsoft.com/en-us/library/windowsphone/develop/jj207023%28v=vs.105%29.aspx