让我假装我有以下xaml ...
<UserControl.Resources>
<local:ViewModel x:Name="viewModel" />
<local:LoadChildrenValueConverter x:Name="valueConverter" />
</UserControl.Resources>
<UserControl.DataContext>
<Binding Source="{StaticResource viewModel}" />
</UserControl.DataContext>
<Grid x:Name="LayoutRoot" Background="White">
<control:TreeView ItemsSource="{Binding Root}">
<control:TreeView.ItemTemplate>
<control:HierarchicalDataTemplate ItemsSource="{Binding Converter={StaticResource valueConverter}}">
<TextBlock Text="{Binding}" />
</control:HierarchicalDataTemplate>
</control:TreeView.ItemTemplate>
</control:TreeView>
</Grid>
......以及下面的代码......
using System;
using System.Collections.ObjectModel;
using System.Windows.Data;
namespace SilverlightViewModelSpike
{
public class ViewModel
{
public ViewModel()
{
Root = new ObservableCollection() { "Item 1", "Item 2", "Item 3", };
}
public ObservableCollection Root { get; private set; }
}
public class LoadChildrenValueConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return new ObservableCollection() { "Item 1", "Item 2", "Item 3", };
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}
}
这可以按预期工作,但是我有两个单独的类来获取我的视图所需的数据(想象一下ViewModel和LoadChildrenValueConverter从Web服务中提取数据而不是返回硬编码数据),这是错误的 . 这里有更好的解决方案吗?我在想也许是这样的......
using System;
using System.Collections.ObjectModel;
using System.Windows.Data;
namespace SilverlightViewModelSpike
{
public class ViewModel
{
public ViewModel()
{
Root = new ObservableCollection() { "Item 1", "Item 2", "Item 3", };
ValueConverter = new LoadChildrenValueConverter();
}
public ObservableCollection Root { get; private set; }
public LoadChildrenValueConverter ValueConverter { get; private set; }
}
public class LoadChildrenValueConverter : IValueConverter
{
public object Convert(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
return new ObservableCollection() { "Item 1", "Item 2", "Item 3", };
}
public object ConvertBack(object value, Type targetType, object parameter, System.Globalization.CultureInfo culture)
{
throw new NotImplementedException();
}
}
}
...但是我不能让这条线工作......
<control:HierarchicalDataTemplate ItemsSource="{???}"
>
......甚至那似乎也不是一个很好的解决方案 . 有人有一个很好的清洁解决方案吗?
2 回答
由于您使用的是ViewModel,它位于实际模型和视图之间,我想知道在那里直接实现IValueConverter逻辑是否更容易 . 有点像:
然后你可以直接绑定到你的第二个属性:
我认为ViewModel对象的主要目的是限制你需要从原始模型中获取所需数据的“技巧”(例如IValueConverters)的数量 . 既然你有一个,你也可以使用它 .
Edit 1
...当然,现在我重新阅读你的帖子,我发现还有更多内容 . 您正在为“Root”集合中的每个项目获取子项 .
如何在ViewModel本身中将IValueConverter实现为静态实例?
现在你应该可以说:
Edit 2
好的,您使用的是Silverlight,因此无法使用{x:Static} .
我能想到的唯一另一个选项是让你重用一个静态资源而不必声明两个,就是直接在你的ViewModel中实现IValueConverter . 如果您需要执行多种类型的转换,这是不好的,但如果您的ViewModel非常狭隘,那么它可以完成这项工作 . 所以:
现在你可以这样做:
对不起家伙我对你在这里想要做什么感到有点困惑...无论如何,从 Headers 听起来好像你想要将 Value 转换器中的属性转换为 Value 转换器中的属性 . 首先看看我写的一篇文章,解释你如何能做到这一点:http://nick-howard.blogspot.com/2011/06/silverlight-4-value-converter.html
那么你要做的是在你的LoadChildrenValueConverter中创建一个ObvervableCollection依赖属性,为了参数,我们称之为Children .
然后在您的xaml中,您可以将LoadChildrenValueConverter更改为以下内容:
这样,您只需从视图模型中调用一次Web服务,然后使用值转换器在视图模型中共享ObvervableCollection .
希望有所帮助 .