wpf - tabControl 中的多个 userControl 实例

标签 wpf datatemplate tabcontrol itemtemplate

我有一个绑定(bind)到可观察集合的 tabControl。
在 headerTemplate 中,我想绑定(bind)到一个字符串属性,并且在 contentTemplate 中我放置了一个用户控件。

这是 MainWindow.xaml 的代码:

<Grid>
    <Grid.Resources>            
        <DataTemplate x:Key="contentTemplate">
                <local:UserControl1 />
        </DataTemplate>

        <DataTemplate x:Key="itemTemplate">
                <Label Content="{Binding Path=Name}" />
        </DataTemplate>
    </Grid.Resources>

    <TabControl IsSynchronizedWithCurrentItem="True" 
                ItemsSource="{Binding Path=Pages}"
                ItemTemplate="{StaticResource itemTemplate}"
                ContentTemplate="{StaticResource contentTemplate}"/>

</Grid>

及其背后的代码:
public partial class MainWindow : Window
{
    public MainWindow()
    {
        InitializeComponent();

        this.DataContext = new MainWindowViewModel();
    }        
}

public class MainWindowViewModel
{
    public ObservableCollection<PageViewModel> Pages { get; set; }

    public MainWindowViewModel()
    {
        this.Pages = new ObservableCollection<PageViewModel>();
        this.Pages.Add(new PageViewModel("first"));
        this.Pages.Add(new PageViewModel("second"));
    }
}

public class PageViewModel
{
    public string Name { get; set; }

    public PageViewModel(string name)
    {
        this.Name = name;
    }
}

所以这种情况下的问题(指定了 itemTemplate 和 controlTemplate)是我只得到 一个 用户控件的实例,我想为每个绑定(bind)的项目创建一个实例。

最佳答案

试试这个:

<TabControl IsSynchronizedWithCurrentItem="True" ItemsSource="{Binding Pages}">
    <TabControl.Resources>
        <DataTemplate x:Key="contentTemplate" x:Shared="False">
            <local:UserControl1/>
        </DataTemplate>
        <Style TargetType="{x:Type TabItem}">
            <Setter Property="Header" Value="{Binding Name}"/>
            <Setter Property="ContentTemplate" Value="{StaticResource contentTemplate}"/>
        </Style>
    </TabControl.Resources>
</TabControl>

关于wpf - tabControl 中的多个 userControl 实例,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/601826/

相关文章:

windows-phone-7 - 当滚动查看器位于数据模板内时设置滚动查看器垂直偏移(wp7)

c# - 访问 View 模型类中的选项卡控件

.net - Windows Server 2012 中的 WPF 应用程序中的颜色错误

wpf - 将两个 UIElements 作为 CommandParameter 传递

wpf - 如何防止视觉画笔拉伸(stretch)其内容

c# - 通过循环将项目添加到 DataContext

c# - 表内每条记录一个堆栈面板

c# - 抑制 GridViewColumn 上的鼠标悬停效果

c# - 使用 Silverlight 在运行时在 tabcontrol 中添加 TabItem

c# - 检查是否选择了特定的标签页(事件)