zoukankan      html  css  js  c++  java
  • Silverlight/WP7 MultiBinding(译)

    在这篇文章里我将介绍去年我写的一个Silverlight 多值绑定的升级版,这个升级版包括Silverlight 4,附加属性和多值绑定到一个对象上。

    多值绑定在WPF中允许绑定多个数据源到单个属性上,此时的绑定要结合数值转换器。但是这一个特性在silverlight中不被支持。一年前,我写了一个关于在silverlight中解决Multibinding的解决方案,它受到了很大的反响。甚至来自微软的Attorney 发了一封邮件给我,说能不能把我写的解决方案用到Silverlight Facebook 客户端上去(多么酷的一件事 )。当听到Stefan Olson 弄了一个升级版使它能够在SL4中使用我很高兴。这篇文章就是简短的介绍一下这些升级的新特性。

    下面这张图就是一个多值绑定的例子:

    在这个示例中,顶部的TextBox通过一个转换器绑定到了数据对象的surnameforename属性上(截取了surname的第一个字母和forename全部)。如果编辑forname或者是surname,顶部的TextBox的值也会相应的改变。这个技巧就是通过不同的转换器链接三个属性并绑定。

    下面就是实现上述功能的XAML代码:

    <TextBlock x:Name="Block" Foreground="White" FontSize="13" Margin="5,0,0,0">
        <local:BindingUtil.MultiBindings>
            <local:MultiBindings>
                <local:MultiBinding TargetProperty="Text"  Converter="{StaticResource Title SummaryConverter}">
                    <local:MultiBinding.Bindings>
                        <local:BindingCollection>
                            <Binding Path="Surname"/>                            
                            <Binding Path="Forename"/>
                            </local:BindingCollection>
                    </local:MultiBinding.Bindings>
                </local:MultiBinding>
                <local:MultiBinding TargetProperty="ToolTipService.ToolTip"  Converter="{StaticResource TitleConverter}">
                    <local:MultiBinding.Bindings>
                        <local:BindingCollection>
                            <Binding Path="Surname"/>                            
                            <Binding Path="Forename"/>
                            <Binding Path="Age"/>
                        </local:BindingCollection>
                    </local:MultiBinding.Bindings>
                </local:MultiBinding>
            </local:MultiBindings>
        </local:BindingUtil.MultiBindings>
    </TextBlock>

    在这里可以看到我们得TextBlock有两个multibinding,一个是关于forenamesurnade ,另一个是包括这三个属性。

    Note:第二个multibinding是绑定ToolTipService的,ToolTip是一个附加属性。


    你可以在这儿下载Silverlight MultiBinding的源码:SLMultiBindingUpdate.zip 再次感谢Stefan Olson把这个特性加到了WPF上。

    如果你对这个技术的原理有兴趣,我推荐你看这篇文章,他描述了为了评估你的bindings代码怎么在可视化树去建立一个虚拟的分支。


    我希望这个升级版本能对你有用,如果你有什么要反馈的,请留言回复。

  • 相关阅读:
    vue路由传参页面刷新参数丢失问题解决方案
    理解MVC,MVP 和 MVVM
    HTTPS用的是对称加密还是非对称加密?
    元素显示隐藏的9种思路
    CSS中层叠上下文
    DOM盒模型和位置 client offset scroll 和滚动的关系
    css重点知识和bug解决方法
    你可能不知道的CSS
    如何在 React 中优雅的写 CSS?
    html5不常用标签应用场景
  • 原文地址:https://www.cnblogs.com/navigator/p/2917687.html
Copyright © 2011-2022 走看看