因此,我尝试使用DependencyProperty
来解决有关在子视图中传递本地ViewModel的问题。然而,我脑海中浮现出一个问题。
例如,我需要制作某个FrameworkElement
的多个实例,例如UserControl
。 UserControl
定义了DependencyProperty
。如书中所述,依赖项属性实例应为static
和readonly
。 DependencyProperty
如何在这种情况下发挥作用?它是否与传统的UserControl
属性相同,或者传递给DependencyProperty
的任何对象实例,它将被传递到所述UserControl
的所有实例?
答案 0 :(得分:2)
是的,它将作为普通财产运作。如果您需要特定控件的属性,即单个控件的一个属性,则可以仅使用依赖项属性。它们将通过该类的所有实例。但是,如果您希望在许多控件上使用该属性,则应使用附加依赖项属性,该属性可供特定命名空间内的所有成员使用。属性,例如:Canvas.Top,DockPanel.Dock 附加 DependencyProperty。
附加依赖属性的示例:
public class MyDependencyClass : DependencyObject
{
public static readonly DependencyProperty IsSelectedProperty;
public static void SetIsSelected(DependencyObject DepObject, Boolean value)
{
DepObject.SetValue(IsSelectedProperty, value);
}
public static Boolean GetIsSelected(DependencyObject DepObject)
{
return (Boolean)DepObject.GetValue(IsSelectedProperty);
}
private static bool IsSelectedValid(object Value)
{
if (Value.GetType() == typeof(bool))
{
return true;
}
else
{
return false;
}
}
static MyDependencyClass()
{
FrameworkPropertyMetadata MetaData = new FrameworkPropertyMetadata((Boolean)false);
IsSelectedProperty = DependencyProperty.RegisterAttached("IsSelected",
typeof(Boolean),
typeof(MyDependencyClass),
MetaData,
new ValidateValueCallback(IsSelectedValid));
}
}
它们还包含有用的回调,例如 OnPropertyChangedCallback , ValidateValueCallback ,它们可以放在一个额外的逻辑中。
这些属性也可在XAML中使用。添加“本地”命名空间:
xmlns:local="clr-namespace:SampleApp"
定义元素:
<Button Name="Button1" local:MyDependencyClass.IsSelected="True" />
<Button Name="Button2" local:MyDependencyClass.IsSelected="False" />
...
<ListBoxItem Name="Sample" local:MyDependencyClass.IsSelected="True" />
触发器中的属性访问:
<Trigger Property="local:MyDependencyClass.IsSelected" Value="True">
<Setter Property="Background" Value="Green" />
</Trigger>
在代码中使用附加的依赖项属性:
if (CurrentButtonName == MyButton.Name)
{
MyDependencyClass.SetIsSelected(CurrentButton, true);
}
else
{
MyDependencyClass.SetIsSelected(CurrentButton, false);
}
有关详细信息,请参阅:http://msdn.microsoft.com/en-us/library/ms749011.aspx