Postupy: Vygenerování hodnoty na základě seznamu připojených položek
MultiBinding umožňuje svázat cílovou vlastnost vazby se seznamem zdrojových vlastností a pak použít logiku pro vytvoření hodnoty s danými vstupy. Tento příklad ukazuje, jak použít MultiBinding.
Příklad
V následujícím příkladu NameListData
odkazuje na kolekci PersonName
objektů, což jsou objekty, které obsahují dvě vlastnosti a firstName
lastName
. Následující příklad vytvoří TextBlock jméno a příjmení osoby s příjmením.
<Window
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:c="clr-namespace:SDKSample"
x:Class="SDKSample.Window1"
Width="400"
Height="280"
Title="MultiBinding Sample">
<Window.Resources>
<c:NameList x:Key="NameListData"/>
<c:NameConverter x:Key="myNameConverter"/>
</Window.Resources>
<TextBlock Name="textBox2" DataContext="{StaticResource NameListData}">
<TextBlock.Text>
<MultiBinding Converter="{StaticResource myNameConverter}"
ConverterParameter="FormatLastFirst">
<Binding Path="FirstName"/>
<Binding Path="LastName"/>
</MultiBinding>
</TextBlock.Text>
</TextBlock>
</Window>
Abychom pochopili, jak se vytváří příjmení a křestní formát, podívejme se na implementaci NameConverter
:
public class NameConverter : IMultiValueConverter
{
public object Convert(object[] values, Type targetType, object parameter, CultureInfo culture)
{
string name;
switch ((string)parameter)
{
case "FormatLastFirst":
name = values[1] + ", " + values[0];
break;
case "FormatNormal":
default:
name = values[0] + " " + values[1];
break;
}
return name;
}
public object[] ConvertBack(object value, Type[] targetTypes, object parameter, CultureInfo culture)
{
string[] splitValues = ((string)value).Split(' ');
return splitValues;
}
}
Public Class NameConverter
Implements IMultiValueConverter
Public Function Convert1(ByVal values() As Object, _
ByVal targetType As System.Type, _
ByVal parameter As Object, _
ByVal culture As System.Globalization.CultureInfo) As Object _
Implements System.Windows.Data.IMultiValueConverter.Convert
Select Case CStr(parameter)
Case "FormatLastFirst"
Return (values(1) & ", " & values(0))
End Select
Return (values(0) & " " & values(1))
End Function
Public Function ConvertBack1(ByVal value As Object, _
ByVal targetTypes() As System.Type, _
ByVal parameter As Object, _
ByVal culture As System.Globalization.CultureInfo) As Object() _
Implements System.Windows.Data.IMultiValueConverter.ConvertBack
Return CStr(value).Split(New Char() {" "c})
End Function
End Class
NameConverter
implementuje IMultiValueConverter rozhraní. NameConverter
přebírá hodnoty z jednotlivých vazeb a ukládá je do pole objektů hodnot. Pořadí, ve kterém Binding se prvky zobrazují pod prvkem MultiBinding , je pořadí, ve kterém jsou tyto hodnoty uloženy v poli. Na hodnotu atributu ConverterParameter odkazuje argument parametru Converter metody, který provádí přepínač parametru, který určuje, jak formátovat název.
Viz také
.NET Desktop feedback