In WinRT, così come in WPF e Windows Phone, non è possibile fare il binding nei converter del ConverterParameter: come è possibile ovviare e fare un binding con più parametri?
Si prenda questo esempio:
<converter:MyConverter x:Key="MyConverter" /> <TextBlock Text="{Binding Title, Converter={StaticResource MyConverter}, ConverterParameter={Binding Subtitle}}" />
In questo caso abbiamo la necessità di fare il binding ad una TextBlock con la proprietà Title, che deve essere elaborata dal converter in base ad un parametro che è a sua volta in binding con la proprietà Subtitle.
Questo scenario non è attualmente sfruttabile, perché, andando a debuggare ci si accorge che, nonostante non ci siano problemi, la proprietà parameter nella funzione di conversione è sempre null.
La ragione principale è che il ConverterParameter non è una DependencyProperty, ma un semplice object, e quindi non è possibile utilizzare il binding.
L'idea più semplice è quella di creare una DependencyProperty per ogni parametro che si desidera avere al posto del ConverterParameter.
Per fare questo bisogna però far ereditare il converter, oltre che da IValueConverter, anche da DependencyObject.
public class MyConverter : DependencyObject, IValueConverter { public string ConverterParameter { get { return (string)GetValue(ConverterParameter Property); } set { SetValue(ConverterParameter Property, value); } } public static readonly DependencyProperty ConverterParameter Property = DependencyProperty.Register("ConverterParameter", typeof (string), typeof (MyConverter), new PropertyMetadata(null)); public object Convert(object value, Type targetType, object parameter, string language) { throw new NotImplementedException(); } public object ConvertBack(object value, Type targetType, object parameter, string language) { throw new NotImplementedException(); } }
Una volta fatto questo, modifichiamo la dichiarazione del converter e della TextBlock come segue:
<converter:MyConverter x:Key="MyConverter" ConverterParameter="{Binding Subtitle}" /> <TextBlock Text="{Binding Title, Converter={StaticResource MyConverter}}"/>
Come avete potuto notare, è possibile create tante DependencyProperty quanti sono i parametri di cui abbiamo bisogno in binding, evitando il limite (tra l'altro non supportato) di un solo elemento del ConverterParameter.
Commenti
Per inserire un commento, devi avere un account.
Fai il login e torna a questa pagina, oppure registrati alla nostra community.
Approfondimenti
Ricevere notifiche sui test con Azure Load Testing
Eseguire query per recuperare il padre di un record che sfrutta il tipo HierarchyID in Entity Framework
Recuperare automaticamente un utente e aggiungerlo ad un gruppo di Azure DevOps
Popolare una classe a partire dal testo, con Semantic Kernel e ASP.NET Core Web API
Il nuovo controllo Range di Blazor 9
Generare una User Delegation SAS in .NET per Azure Blob Storage
Gestione degli stili CSS con le regole @layer
Supportare lo HierarchyID di Sql Server in Entity Framework 8
Utilizzare la funzione EF.Parameter per forzare la parametrizzazione di una costante con Entity Framework
Cambiare la chiave di partizionamento di Azure Cosmos DB
Utilizzare QuickGrid di Blazor con Entity Framework
Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
I più letti di oggi
- ecco tutte le novità pubblicate sui nostri siti questa settimana: https://aspit.co/wkly buon week-end!
- Autenticazione di git tramite Microsoft Entra ID in Azure DevOps
- Utilizzare angular-cli per creare un service in Angular 2
- Repaint, Reflow e Compositing: Come Funziona il Rendering nel Browser
- Utilizzare Hybrid Cache in .NET 9
- Tutorial ASP.NET MVC