0

我无法将用户控件上的自定义依赖属性绑定到我的 MVVM ViewModel。当我直接在视图上使用它时,我的用户控件正常工作:

    <local:CustomControl Mode="{Binding Mode, Mode=TwoWay}" HorizontalAlignment="Stretch" VerticalAlignment="Stretch"  Grid.Row="0">
        <Button x:Name="InfoBox1" Content="Test1" />
        <Button x:Name="InfoBox2" Content="Test2" />
    </local:CustomControl>

但是将其用作项目面板模板绑定不起作用:

    <ItemsControl Grid.Row="0" ItemsSource="{Binding Equipment}">
        <ItemsControl.ItemsPanel>
            <ItemsPanelTemplate>
                <local:CustomControl Mode="{Binding Mode, Mode=TwoWay}"/>
            </ItemsPanelTemplate>
        </ItemsControl.ItemsPanel>
        <ItemsControl.ItemTemplate>
            <DataTemplate>
                ...
            </DataTemplate>
        </ItemsControl.ItemTemplate>
    </ItemsControl>

我尝试使用 RelativeSource 并找到 itemscontrol/view 并将路径设置为 Mode 或 DataContext.Mode 但我无法使绑定工作。

模式定义为:

    public static readonly DependencyProperty ModeProperty;

    public Modes Mode
    {
        get { return (Modes)this.GetValue(ModeProperty); }
        set { this.SetValue(ModeProperty, value); }
    }

并在自定义控件的构造函数中注册:

    public CustomControl()
    {
        Mode = Modes.Default;
    }

    static CustomControl()
    {
        ModeProperty = DependencyProperty.Register("Mode", typeof(Modes), typeof(CustomControl), new FrameworkPropertyMetadata(Mode.Default, OnModeChanged));
    }

    private static void OnModeChanged(DependencyObject o, DependencyPropertyChangedEventArgs e)
    {
        CustomControl ctrl= o as CustomControl ;
        if (ctrl== null) return;

        Modes mode = (Modes)e.NewValue;
        ctrl.Mode = mode;
    }

我是否需要使用解决方法来使控件作为面板模板工作,还是我只是把绑定搞砸了?

- - 编辑

视图模型部分:

    private Modes _mode= Modes.Default;
    public Modes Mode
    {
        get { return _mode; }
        set { _mode= value; NotifyPropertyChanged(); }
    }

    private ObservableCollection<EquipmentViewModel> _equipment;
    public ObservableCollection<EquipmentViewModel> Equipment
    {
        get { return _equipment; }
        set { _equipment = value; NotifyPropertyChanged(); }
    }

----Edit2:我已经进一步调查并且我更加复杂。我已将以下内容添加到 ItemsPanelTemplate 的控件和直接在网格中的控件。

 Visibility="{Binding Visible, Converter={StaticResource visibilityConverter}}"

在这两种情况下,更改此 Visible 布尔值都有效。因此,这似乎只是自定义 DependencyProperty 的问题。

检查可视化树控件的 DataContext 作为 ItemsPanelTemplate 也是正确的。

当直接使用而不是用作 itemspaneltemplate 时,什么可以使依赖属性正常工作?

4

1 回答 1

0

找到导致奇怪冲突行为的原因。我在普通 ctor 中将属性设置为某个值

public CustomControl()
{
    Mode = Modes.Default;
}

将控件用作 Itemspanel 模板时,这显然会导致冲突。删除它使绑定按预期工作。

我猜行为的差异与在不同时间对构造函数的调用有关吗?

于 2017-05-04T13:43:34.567 回答