Подтвердить что ты не робот

Привязка к свойству зависимостей пользовательского элемента управления WPF/XAML

Мое приложение выглядит следующим образом:


SectionHeader

SectionHeader

Содержание

SectionHeader

Содержание


SectionHeader - это пользовательский элемент управления с двумя свойствами зависимостей = Title и Apps.

Заголовок не изменяется, но приложения должны быть привязаны к свойству приложения "Свойства окна главного окна". Свойство Apps требуется только для двух из трех заголовков разделов.

<c:SectionHeader DockPanel.Dock="Top" x:Name="SectionResources" Title="RESOURCES"
   Apps="{Binding Path=Apps}" />

Так оно и есть на данный момент. Проблема в том, что приложения не отображаются.

В SectionHeader DataContext устанавливается в себя следующим образом, что позволяет отображать Title.

DataContext="{Binding RelativeSource={RelativeSource Self}}"

Приложения - это ItemSource для ItemsControl в UserControl:

<ItemsControl
      ItemsSource="{Binding Apps}">

Итак, мои вопросы:

  • Как привязать данные к UserControl DP?
  • Это более простой способ сделать этот макет без UserControls?

EDIT:

Забыл упомянуть, что Apps - это ObservableCollection of AppsItems.

Вот как выглядит мой DP:

public static readonly DependencyProperty AppsProperty = DependencyProperty.Register("Apps",
  typeof (ObservableCollection<AppsItem>), typeof (SectionHeader),
  new PropertyMetadata(null, OnAppsPropertyChanged));

private static void OnAppsPropertyChanged(DependencyObject d, DependencyPropertyChangedEventArgs e)
{
  Console.WriteLine("Hello!!!");
  var sectionHeader = d as SectionHeader;
  var value = e.NewValue as ObservableCollection<AppsItem>;
  sectionHeader.Apps = value;
}
4b9b3361

Ответ 1

Дайте имя вашему usecontrol и попробуйте привязать его как

ItemsSource="{Binding Apps,ElementName=root}"

и root - это имя, которое дает вашему usercontrol

  <UserControl x:Class="WpfApplication1.MainWindow"
            xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
            xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             Height="350" Width="525"
     x:Name="root">

это привязка элемента к пользовательскому элементу управления, у которого есть свойство Apps

Ответ 2

Попробовав воспроизвести это из вашего описания и столкнувшись с подобной проблемой, я обнаружил, что единственный способ заставить его работать - не устанавливать DataContext для UserControl и вместо этого использовать ElementBinding:

<UserControl x:Class="WpfApplication2.UserControl1"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
             xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" 
             xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
             mc:Ignorable="d" 
             x:Name="thisUC"
             d:DesignHeight="300" d:DesignWidth="300">
    <Grid>
        <Border Background="Red" Padding="10">
        <ListBox x:Name="ucList" ItemsSource="{Binding ElementName=thisUC, Path=UCApps}"/>
        </Border>

    </Grid>
</UserControl>

Реализация этого UC тривиально проста:

using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
using System.Windows;
using System.Windows.Controls;
using System.Windows.Data;
using System.Windows.Documents;
using System.Windows.Input;
using System.Windows.Media;
using System.Windows.Media.Imaging;
using System.Windows.Navigation;
using System.Windows.Shapes;
using System.Collections.ObjectModel;
using System.Collections;

namespace WpfApplication2
{
    /// <summary>
    /// Interaction logic for UserControl1.xaml
    /// </summary>
    public partial class UserControl1 : UserControl
    {
        public IEnumerable UCApps
        {
            get { return (IEnumerable)GetValue(UCAppsProperty); }
            set { SetValue(UCAppsProperty, value); }
        }

        // Using a DependencyProperty as the backing store for Apps.  This enables animation, styling, binding, etc...
        public static readonly DependencyProperty UCAppsProperty =
            DependencyProperty.Register("UCApps", typeof(IEnumerable), typeof(UserControl1), new UIPropertyMetadata(null));

        public UserControl1()
        {
            InitializeComponent();            
        }
    }
}

как и XAML, который его вызывает:

<Grid >
    <my:UserControl1 x:Name="ucName" UCApps="{Binding Path=Apps}"/>
</Grid>

(Я изменил имя Apps в вашем Usercontrol на UCApps, чтобы я мог видеть, что происходит - слишком много свойств с тем же именем запутались!)

Ответ 3

Apps="{Binding Path=Apps}"

Привязывает приложения к себе.

Попробуйте выполнить

1) Ваша ViewModel должна быть элементом управления DataContext, тогда вы можете использовать следующие

Apps="{Binding DataContext.Apps}"

Также вы можете использовать утилиту Snoop, чтобы найти проблемы с привязкой в ​​режиме реального времени

Ответ 4

Вы пробовали

Apps="{Binding Apps}" 

вместо

Apps="{Binding Path=Apps}"

в вашем верхнем уровне управления?

Также вы получаете какие-либо ошибки привязки в окне вывода VS при запуске приложения?