Instrukcje: tworzenie wartości na podstawie listy powiązanych elementów
MultiBinding umożliwia powiązanie właściwości docelowej powiązania z listą właściwości źródłowych, a następnie zastosowanie logiki w celu utworzenia wartości z podanymi danymi wejściowymi. W tym przykładzie pokazano, jak używać MultiBinding.
Przykład
W poniższym przykładzie NameListData
odnosi się do kolekcji obiektów PersonName
, które są obiektami zawierającymi dwie właściwości, firstName
i lastName
. W poniższym przykładzie utworzony zostanie TextBlock, który pokazuje nazwisko i imię osoby, zaczynając od nazwiska.
<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>
Aby dowiedzieć się, jak jest generowany format last-name-first, przyjrzyjmy się implementacji 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 interfejs IMultiValueConverter.
NameConverter
pobiera wartości z poszczególnych powiązań i przechowuje je w tablicy obiektów wartości. Kolejność, w której elementy Binding występują pod elementem MultiBinding, jest kolejnością przechowywania tych wartości w tablicy. Wartość atrybutu ConverterParameter jest przywoływana przez argument parametru metody Converter, która wykonuje przełącznik na parametrze w celu określenia sposobu formatowania nazwy.
Zobacz też
.NET Desktop feedback