WPF与Prism一并学习(三)
2017-12-01 08:52
246 查看
深度解析
TypeConverter & TypeConverterAttribute (一)
深度解析
TypeConverter & TypeConverterAttribute (二)
使用TypeConverter类将XAML标签的Attribute与对象的Property进行映射
先我们准备一个类:
[csharp] view plaincopyprint?
public class Human
{
public string Name{get;set;}
public Human Child { get; set; }
}
这个类具有连个属性:
String类型的Name;
Human类型的Child;
现在我们期望的是,如果我们在XAML里面这样写:
[html] view plaincopyprint?
<Window.Resources>
<local:Human x:Key="human" child="ABC"></local:Human>
</Window.Resources>
则能够为Human实例的Child属性赋一个Human类型的值,并且Child.Name就是这个字符串的值。
我们点看看直接写行不行。在UI上添加一个Button,并在Click事件里面写上:
[csharp] view plaincopyprint?
Human human = (Human)this.FindResource("human");
MessageBox.Show(human.Child.Name);
编译没有问题,但是在单击按钮的时候会弹出异常,告诉Child不存在,为什么Child不存在呢?原因很简单,Human的Child属性是Human类型,而XAML代码中的ABC是个字符串,编译器不知道如何将一个字符串转换成一个Human实例。那我们应该怎么办呢?办法是使用TypeConverter和TypeConvertAttribute这两个类。
首先,我们要从TypeConvert派生出自己的类,并重写它的ConverFrom方法。这个方法有一个参数名叫做Value,这个值就是XAML文档里面为其设置的值。我们要做的就是将这个值翻译成合适对象的值并赋值给对象的属性:
[csharp] view plaincopyprint?
public class StringToHumanTypeConverter:TypeConverter
{
public override object ConvertFrom(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value)
{
if(value is string)
{
Human human = new Human();
human.Name = value as string;
return human;
}
return base.ConvertFrom(context, culture, value);
}
}
有了这个类还不够,你还需要使用TypeConvertAtrribute这个特征类把StringToHumanTypeConverter这个类"粘贴"到作为目标的Human类上。
[csharp] view plaincopyprint?
[TypeConverterAttribute(typeof(StringToHumanTypeConverter))]
public class Human
{
public string Name{get;set;}
public Human Child { get; set; }
}
因为特征类在书写的时候可以省略Attribute这个词,所以也可以写作:
[csharp] view plaincopyprint?
[TypeConverter(typeof(StringToHumanTypeConverter))]
public class Human
{
public string Name{get;set;}
public Human Child { get; set; }
}
但这样写,我们需要认清括号里是TypeConverterAttribute而不是TypeConverter。
完成之后我们再单击按钮,我们想要的结果出来了,如下图:
注意:
TypeConverter类的使用远远不只是重载一个ConvertFrom方法这么简单,为了配合这个方法的运行,还需要重载其它几个方法。详细的使用方法请参见TypeConvert类库文档。
TypeConverter & TypeConverterAttribute (一)
深度解析
TypeConverter & TypeConverterAttribute (二)
使用TypeConverter类将XAML标签的Attribute与对象的Property进行映射
先我们准备一个类:
[csharp] view plaincopyprint?
public class Human
{
public string Name{get;set;}
public Human Child { get; set; }
}
这个类具有连个属性:
String类型的Name;
Human类型的Child;
现在我们期望的是,如果我们在XAML里面这样写:
[html] view plaincopyprint?
<Window.Resources>
<local:Human x:Key="human" child="ABC"></local:Human>
</Window.Resources>
则能够为Human实例的Child属性赋一个Human类型的值,并且Child.Name就是这个字符串的值。
我们点看看直接写行不行。在UI上添加一个Button,并在Click事件里面写上:
[csharp] view plaincopyprint?
Human human = (Human)this.FindResource("human");
MessageBox.Show(human.Child.Name);
编译没有问题,但是在单击按钮的时候会弹出异常,告诉Child不存在,为什么Child不存在呢?原因很简单,Human的Child属性是Human类型,而XAML代码中的ABC是个字符串,编译器不知道如何将一个字符串转换成一个Human实例。那我们应该怎么办呢?办法是使用TypeConverter和TypeConvertAttribute这两个类。
首先,我们要从TypeConvert派生出自己的类,并重写它的ConverFrom方法。这个方法有一个参数名叫做Value,这个值就是XAML文档里面为其设置的值。我们要做的就是将这个值翻译成合适对象的值并赋值给对象的属性:
[csharp] view plaincopyprint?
public class StringToHumanTypeConverter:TypeConverter
{
public override object ConvertFrom(ITypeDescriptorContext context, System.Globalization.CultureInfo culture, object value)
{
if(value is string)
{
Human human = new Human();
human.Name = value as string;
return human;
}
return base.ConvertFrom(context, culture, value);
}
}
有了这个类还不够,你还需要使用TypeConvertAtrribute这个特征类把StringToHumanTypeConverter这个类"粘贴"到作为目标的Human类上。
[csharp] view plaincopyprint?
[TypeConverterAttribute(typeof(StringToHumanTypeConverter))]
public class Human
{
public string Name{get;set;}
public Human Child { get; set; }
}
因为特征类在书写的时候可以省略Attribute这个词,所以也可以写作:
[csharp] view plaincopyprint?
[TypeConverter(typeof(StringToHumanTypeConverter))]
public class Human
{
public string Name{get;set;}
public Human Child { get; set; }
}
但这样写,我们需要认清括号里是TypeConverterAttribute而不是TypeConverter。
完成之后我们再单击按钮,我们想要的结果出来了,如下图:
注意:
TypeConverter类的使用远远不只是重载一个ConvertFrom方法这么简单,为了配合这个方法的运行,还需要重载其它几个方法。详细的使用方法请参见TypeConvert类库文档。
相关文章推荐
- WPF与Prism一并学习(四)
- WPF与Prism一并学习(二)
- WPF与Prism一并学习(一)
- WPF与Prism一并学习(二)
- WPF与Prism一并学习(三)
- WPF与Prism一并学习(四)
- WPF与Prism一并学习(四)
- WPF与Prism一并学习(三)
- WPF与Prism一并学习(一)
- WPF与Prism一并学习(五)
- WPF与Prism一并学习(五)
- WPF与Prism一并学习(一)
- WPF与Prism一并学习(二)
- WPF与Prism一并学习(五)
- WPF、MVVM和Prism学习历程
- 学习WPF Prism框架开发的好博客
- WPF、MVVM和Prism学习历程
- 潜移默化学会WPF--ProcessBar学习(一)
- 分享Silverlight/WPF/Windows Phone一周学习导读(12月20日-12月26日)
- WPF学习笔记-自定义窗口