前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >UWP基础教程 - XAML类型转换器

UWP基础教程 - XAML类型转换器

作者头像
陈仁松
发布2018-03-20 10:29:38
1.5K0
发布2018-03-20 10:29:38
举报
文章被收录于专栏:陈仁松博客陈仁松博客

在XAML中每一个元素对象对应一个实例,而实例属性可以通过属性进行赋值。在实际项目开发中,对象元素的属性值可以是不同数据类型,根据需求不同,经常需要对数据类型进行转换,就需要使用XAML的类型转换器(Type Converters)。本文将讲解XAML类型转换器的使用。

在Windows 10 UWP应用开发中,经常会用到类型转换器,例如对按钮的内容进行赋值,代码如下:

代码语言:javascript
复制
<Button Content="演示按钮"/>

ButtonContent属性被赋值为字符串类型“演示按钮”。XAML语法解析器可以将字符串类型转换为对应的.Net类型,然后进行赋值操作。而如果在按钮控件中,添加内容文本颜色属性,

代码语言:javascript
复制
<Button Content="按钮演示" Foreground="Red"/>

在.Net Framework中,Foreground属性的数据类型是Brush,通过SolidColorBrush对Color进行赋值,在以上代码中,XAML语法解析器需要使用类型转换器(Type Converters)将简单文本字符串“Red”,转换为对应的“Brush”画刷类型,其颜色值为Red=255,Green=0,Blue=0,Aplha=255。 对应后台代码类型转换是:

代码语言:javascript
复制
Button button = new Button { Foreground = new SolidColorBrush(Color.FromArgb(255, 0, 0, 255)) };

这一转换过程是由.Net Framework内置类型转换器实现的,无需开发人员干涉。

转换过程主要是以下两个步骤:

  1. XAML语法解析器会检查需要赋值的属性是否存在内置类型转换器,如果发现对应类型转换器,则将属性的属性值字符串转换为对应的.Net类型;
  2. 如果没有发现内置类型转换器,XAML语法解析器将查找元素对象中是否使用标记扩展(Markup Extensions)调用自定义类型转换器;

如果以上两个步骤都没有发现对应类型转换器的存在,XAML语法解析器将返回类型错误。 因为XAML支持标记扩展(Markup Extensions),可以在运行时对属性进行赋值,而属性值类型通常需要进行对应的类型转换才能正常使用,所以在实际项目中,经常会用到XAML类型转换器功能,不仅仅局限于项目内置类型转换器,同时还允许开发人员通过继承TypeConverter类创建自定义类型转换器。

下面来看一下如何自定义一个类型转化器

代码语言:javascript
复制
class BoolToVisibilityConverter : IValueConverter
{
    public object Convert(object value, Type targetType, object parameter, string language)
    {
        if (value == null)
            return Visibility.Visible;
        return (bool)value ? Visibility.Visible : Visibility.Collapsed;
    }

    public object ConvertBack(object value, Type targetType, object parameter, string language)
    {
        if (value == null)
            return true;
        return ((Visibility)value == Visibility.Visible);
    }
}

XAML类型转换器必须实现接口IValueConverter,在ConvertConvertBack中创建转换器逻辑代码。

上面的例子就是将Bool类型转化为Visibility类型,以及将Visibility类型反转为Bool类型

代码语言:javascript
复制
<Page.Resources>
    <local:BoolToVisibilityConverter x:key = "converter"
</Page.Resources>

<TextBox Visibility = {Binding isShow , Converter={StaticResource converter}} />

使用方法如上,ConvertBack主要用于双向绑定中,如果没有双向绑定的需求,可以只实现Convert即可。

在C#代码里面可以这么写

代码语言:javascript
复制
Test test= new Test();
test.isShow = false;
 
Binding binding = new Binding( "isShow" );
binding.Source = test;
binding.Converter = new BoolToVisibilityConverter();

大家可以动手试试,有什么问题欢迎留言。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档