2

いくつかの項目にバインドする TabControl があります。その下には、アイテムを動的に追加できるボタンがあります。項目を追加すると、新しい項目がアクティブなタブになります (TabControl.SelectedItem で正常に動作します)。

<Window x:Class="WpfApplication1.MainWindow"
        xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
        xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
        xmlns:this="clr-namespace:WpfApplication1"
        Title="MainWindow" Height="350" Width="525">
    <StackPanel>
        <TabControl ItemsSource="{Binding Items}"
                    SelectedItem="{Binding SelectedItem, Mode=OneWay}">
            <TabControl.ContentTemplate>
                <DataTemplate>
                    <this:UserControl1 />
                </DataTemplate>
            </TabControl.ContentTemplate>
        </TabControl>
        <Button Content="Foo" Click="Button_Click"/>
    </StackPanel>
</Window>

分離コード:

using System.Collections.ObjectModel;
using System.ComponentModel;
using System.Linq;
using System.Windows;

namespace WpfApplication1
{
    public partial class MainWindow : INotifyPropertyChanged
    {
        public ObservableCollection<Foo> Items { get; set; }
        public Foo SelectedItem { get { return Items.Last(); } }
        public event PropertyChangedEventHandler PropertyChanged;

        public MainWindow()
        {
            Items = new ObservableCollection<Foo>();
            Items.Add(new Foo {Bar = "bar"});

            InitializeComponent();
            DataContext = this;
        }

        private void Button_Click(object sender, RoutedEventArgs e)
        {
            Items.Add(new Foo {Bar = "bar"});

            if (PropertyChanged != null)
            {
                PropertyChanged(this, new PropertyChangedEventArgs("Items"));
                PropertyChanged(this, new PropertyChangedEventArgs("SelectedItem"));
            }
        }
    }

    public class Foo { public string Bar { get; set; } }
}

UserControl1 は次のようになります。

<UserControl x:Class="WpfApplication1.UserControl1"
             xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
             xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml">
    <StackPanel>
        <TextBox/>
        <TextBox x:Name="_textBox"
             DataContextChanged="OnDataContextChanged"
             Text="{Binding Bar}" />
    </StackPanel>
</UserControl>

また、ユーザーがタブをクリックしたときに、コード ビハインドは _textBox にフォーカスし、そのテキストを selectAll にする必要があります。

using System.Windows;

namespace WpfApplication1
{
    public partial class UserControl1
    {
        public UserControl1()
        {
            InitializeComponent();
        }

        private void OnDataContextChanged(object sender,
                                          DependencyPropertyChangedEventArgs e)
        {
            _textBox.Focus();
            _textBox.SelectAll();
        }
    }
}

私は DataContextChanged イベントでそれを達成しようとしましたが、その予測不可能性 (sf http://msdn.microsoft.com/en-us/library/system.windows.frameworkelement.datacontextchanged.aspx ) のため、機能しません。いつも。Loaded イベントでも試してみましたが、これは DataTemplate が読み込まれたときに 1 回だけ呼び出されます。

したがって、DataContext が変更され、データ バインディング エンジンがジョブを完了するたびに、Loaded イベントを受け取る必要があると思います。そのようなイベントはありますか?

4

1 に答える 1

0

ユーザーがタブを追加したときと、ユーザーが別のタブをクリックしたときにテキストを選択したいですか?

この場合、2 つのイベント ハンドラー (タブ コントロールのタブ変更イベント) でこれを処理し、新しい項目を追加するときにコードで設定することができます。

コードによる DataContext は変更されません。メイン ウィンドウに設定され、子コントロールに継承されます。

    public MainWindow()
    {
        Items = new ObservableCollection<Foo>();
        Items.Add(new Foo {Bar = "bar"});

        InitializeComponent();
        DataContext = this;
    }
于 2011-08-23T03:37:12.457 に答える