مشاركة عبر


كيفية القيام بما يلي: إنشاء و الربط إلى ObservableCollection

هذا المثال يوضح كيفية إنشاء وربط المجموعة التي تستمد من فئة ObservableCollection<T> و التي هي فئة مجموعة توفر إعلامات عند الحصول على إضافة العناصر أو إزالتها.

مثال

يظهر المثال التالي تطبيق تجميع NameList :

Public Class NameList
    Inherits ObservableCollection(Of PersonName)

    ' Methods
    Public Sub New()
        MyBase.Add(New PersonName("Willa", "Cather"))
        MyBase.Add(New PersonName("Isak", "Dinesen"))
        MyBase.Add(New PersonName("Victor", "Hugo"))
        MyBase.Add(New PersonName("Jules", "Verne"))
    End Sub

End Class

Public Class PersonName
    ' Methods
    Public Sub New(ByVal first As String, ByVal last As String)
        Me._firstName = first
        Me._lastName = last
    End Sub


    ' Properties
    Public Property FirstName() As String
        Get
            Return Me._firstName
        End Get
        Set(ByVal value As String)
            Me._firstName = value
        End Set
    End Property

    Public Property LastName() As String
        Get
            Return Me._lastName
        End Get
        Set(ByVal value As String)
            Me._lastName = value
        End Set
    End Property


    ' Fields
    Private _firstName As String
    Private _lastName As String
End Class
public class NameList : ObservableCollection<PersonName>
{
    public NameList() : base()
    {
        Add(new PersonName("Willa", "Cather"));
        Add(new PersonName("Isak", "Dinesen"));
        Add(new PersonName("Victor", "Hugo"));
        Add(new PersonName("Jules", "Verne"));
    }
  }

  public class PersonName
  {
      private string firstName;
      private string lastName;

      public PersonName(string first, string last)
      {
          this.firstName = first;
          this.lastName = last;
      }

      public string FirstName
      {
          get { return firstName; }
          set { firstName = value; }
      }

      public string LastName
      {
          get { return lastName; }
          set { lastName = value; }
      }
  }

يمكنك جعل المتاحة لجمع ملزم بنفس الطريقة تفعل مع غيرها من كائنات وقت تشغيل اللغة العامة (CLR) الأخرى كما هو موضح في كيفية القيام بما يلي: توفير البيانات لربط في XAML. على سبيل المثال، يمكنك إنشاء مثيل في XAML وتحديد مجموعة كمورد ، كما هو موضح هنا :


<Window
  xmlns="https://schemas.microsoft.com/winfx/2006/xaml/presentation"
  xmlns:x="https://schemas.microsoft.com/winfx/2006/xaml"
  xmlns:c="clr-namespace:SDKSample"
  x:Class="SDKSample.Window1"
  Width="400"
  Height="280"
  Title="MultiBinding Sample">
    
  <Window.Resources>
    <c:NameList x:Key="NameListData"/>


...


</Window.Resources>

يمكنك الربط بعد ذلك الحين لجمع :

<ListBox Width="200"
         ItemsSource="{Binding Source={StaticResource NameListData}}"
         ItemTemplate="{StaticResource NameItemTemplate}"
         IsSynchronizedWithCurrentItem="True"/>

تعريف NameItemTemplate لا يظهر هنا.

ملاحظةملاحظة

ويجب على الكائنات الخاصة بك في جمع تلبية متطلبات تم وصفها في نظرة عامة حول مصادر الربط.بشكل خاص ، إذا كنت تستخدم OneWay أو TwoWay (على سبيل المثال، تحتاج واجهة المستخدم الخاص بك للتحديث عند تغيير خصائص المصدر بشكل حيوي) ، يجب تطبيق تغيير مناسب لآلية الإعلام مثل واجهة INotifyPropertyChanged .

لمزيد من المعلومات ، راجع قسم التجليد إلى مجموعات في نظرة عامة لربط البيانات.

راجع أيضًا:

المهام

كيفية القيام بما يلي: فرز البيانات في العرض

كيفية القيام بما يلي: تصفية البيانات في عرض

كيفية القيام بما يلي: فرز وتجميع بيانات باستخدام طريقة عرض في XAML

المبادئ

نظرة عامة لربط البيانات

موارد أخرى

المواضيع الإجرائية لربط البيانات