我想从Xaml的类型中确定一种依赖性财产。 这样做会奏效,但当我以暗中或明确的方式确定这一价值时,就会提出例外(无动于衷的例外)。
I created an empty Silverlight application and added a user control (DataFormControl). Here is the code behind of this control:
public DataFormControl()
{
InitializeComponent();
}
public static readonly DependencyProperty TitleProperty = DependencyProperty.Register("Title", typeof(string), typeof(DataFormControl), null);
public string Title
{
get { return (string)GetValue(TitleProperty); }
set { SetValue(TitleProperty, value); }
}
public static readonly DependencyProperty TypeToReflectProperty = DependencyProperty.Register("TypeToReflect", typeof(Type), typeof(DataFormControl), null);
public Type TypeToReflect
{
get { return (Type)GetValue(TypeToReflectProperty); }
set { SetValue(TypeToReflectProperty, value); }
}
public string GetCombo()
{
string returnValue = (Title ?? "no title") + " ; " + (TypeToReflect != null ? TypeToReflect.Name : "unkown Type");
return returnValue;
}
private void Refresh_Button(object sender, RoutedEventArgs e)
{
this.ResultBox.Text = GetCombo();
}
在这里,《欧洲刑法》:
<Grid x:Name="LayoutRoot">
<StackPanel Orientation="Horizontal">
<Button Click="Refresh_Button">Refresh</Button>
<TextBlock x:Name="ResultBox" />
</StackPanel>
</Grid>
现在,问题在于控制着这种控制,并利用全球搭配:
<StackPanel>
<StackPanel.Resources>
<Style TargetType="local:DataFormControl">
<Setter Property="Title" Value="Implicit Name" />
<Setter Property="TypeToReflect" Value="local:DataFormControl" />
</Style>
</StackPanel.Resources>
<TextBlock FontWeight="Bold">Test App</TextBlock>
<local:DataFormControl Title="123" />
<local:DataFormControl Title="Kuh" />
<local:DataFormControl TypeToReflect="local:DataFormControl" />
<local:DataFormControl />
</StackPanel>
如果我删除“TypeToReflect”——那么,所有工作都是罚款的。 全球产权的捆绑也进行罚款。
这是否是一种骗子?
我需要这种说法,因为我想对此进行思考。
例外信息:
Message is always. [Line: 0 Position: 0]
ExceptionType: Unhandled Exception
ExceptionObject: XamlParseException
<>Stacktrace:
at MS.Internal.XcpImports.CheckHResult(UInt32 hr)
at MS.Internal.XcpImports.ConvertStringToTypedCValue(IntPtr pContext, UInt32 cClrTypeName, String clrTypeName, UInt32 cValue, String value, CValue& outVal, Int32& typeIndex)
at MS.Internal.SilverlightTypeConverter.ConvertFrom(ITypeDescriptorContext context, CultureInfo culture, Object value)
at MS.Internal.XcpImports.GetManagedPropertyValueFromStyle(Boolean useBuiltInStyle, IManagedPeerBase obj, DependencyProperty property, Object& value)
at System.Windows.FrameworkElement.GetValueFromStyle(DependencyProperty property, Object& value)
at System.Windows.DependencyObject.EvaluateBaseValue(DependencyProperty property, EffectiveValueEntry oldEntry, EffectiveValueEntry& newEntry, ValueOperation operation)
at System.Windows.DependencyObject.EvaluateEffectiveValue(DependencyProperty property, EffectiveValueEntry oldEntry, EffectiveValueEntry newEntry, ValueOperation operation)
at System.Windows.DependencyObject.UpdateEffectiveValue(DependencyProperty property, EffectiveValueEntry oldEntry, EffectiveValueEntry& newEntry, ValueOperation operation)
at System.Windows.DependencyObject.InvalidateProperty(DependencyProperty property)
at MS.Internal.FrameworkCallbacks.InvalidateProperty(IntPtr nativeTarget, UInt32 propertyId)
内部欺骗是无效的。