WPF DataTemplate绑定

时间:2014-07-02 14:39:02

标签: c# wpf data-binding datatemplate

我发现在WPF TabControl中使用ContentTemplate / DataTemplate时,我的Bindings将不再起作用。

我已经设置了一个小例子来说明:

<Window x:Class="HAND.BindingExample"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="BindingExample" Height="506" Width="656"
    DataContext="{Binding RelativeSource={RelativeSource Self}}"
    >
<Grid>
    <TabControl HorizontalAlignment="Left" Height="381"  VerticalAlignment="Top" Width="608">
        <TabItem Header="TabItem">
            <Label Content="{Binding Path=myString}"/>
        </TabItem>
        <TabItem Header="TabItem">
            <TabItem.ContentTemplate>
                <DataTemplate>
                    <Label Content="{Binding Path=myString}"/>
                </DataTemplate>
            </TabItem.ContentTemplate>
        </TabItem>
    </TabControl>
</Grid>
</Window>

Tab1按预期工作,Tab2为空。

背后的代码:

using System.Windows;

namespace HAND
{
    public partial class BindingExample : Window
    {
        public string myString { get; set; }

        public BindingExample()
        {
            myString = "Hello Stackoverflow";

            InitializeComponent();
        }
    }
}

2 个答案:

答案 0 :(得分:4)

您错误地使用了ContentTemplate属性。来自MSDN上的ContentControl.ContentTemplate Property页:

  

获取或设置用于显示ContentControl内容的数据模板。

因此,在设置此属性时,还需要将Content属性设置为某种数据源:

<TabControl>
    <TabItem Header="TabItem">
        <Label Content="{Binding Path=myString}"/>
    </TabItem>
    <TabItem Header="TabItem" Content="{Binding Path=myString}">
        <TabItem.ContentTemplate>
            <DataTemplate>
                <Label Content="{Binding}" />
            </DataTemplate>
        </TabItem.ContentTemplate>
    </TabItem>
</TabControl>

答案 1 :(得分:3)

<TabItem Content="{Binding myString}" Header="TabItem">
    <TabItem.ContentTemplate>
        <DataTemplate>
            <Label Content="{Binding}" />
        </DataTemplate>
    </TabItem.ContentTemplate>
</TabItem>

但是你知道,将窗口绑在自身上,就不是那样了。 我不知道你是否只是为了这个例子而做了,但如果没有尝试创建一个合适的viewModel来绑定你的窗口;)