在带有TextBoxes的ListBox中,如何关注添加的TextBox? 我尝试过的事情

我有一个文本框列表框和一个将新项添加到列表框的按钮。当我单击添加按钮时,我希望选择新项,并希望包含的文本框具有焦点。

我可以通过绑定轻松地选择新项目,但是我还没有弄清楚如何集中显示文本框。我无法从视图模型中完成此操作,因为新的文本框要等到以后才能创建。

为了向您展示问题,我创建了一个示例解决方案(在GitHub:TestListBoxWithTextBox上提供)。

这是XAML:

<Window
    x:Class="TestListBoxWithTextBox.MainWindow"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    Title="MainWindow"
    >
    <StackPanel>
        <ListBox
            ItemsSource="{Binding Items}"
            SelectedItem="{Binding SelectedItem}"
            >
            <ListBox.ItemTemplate>
                <DataTemplate>
                    <TextBox Text="{Binding Name}" />
                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>
        <Button
            Content="Add"
            Command="{Binding AddItemCommand}"
            />
    </StackPanel>
</Window>

这是我的视图模型(ViewModelBase来自MVVM Light Toolkit):

public class MainViewModel : ViewModelBase
{
    public ObservableCollection<ItemViewModel> Items { get; } =
        new ObservableCollection<ItemViewModel>();

    private ItemViewModel selectedItem;
    public ItemViewModel SelectedItem
    {
        get => selectedItem;
        set => Set(nameof(SelectedItem),ref selectedItem,value);
    }

    public ICommand AddItemCommand =>
        new RelayCommand(() =>
        {
            var newItem = new ItemViewModel();
            Items.Add(newItem);
            SelectedItem = newItem;
        });
}

public class ItemViewModel : ViewModelBase
{
    private string name;
    public string Name
    {
        get => name;
        set => Set(nameof(Name),ref name,value);
    }
}

我尝试过的事情

从视图模型与视图对话:我使用方法IView创建了一个接口FocusTextBox(int index)。视图实现了此接口,并且视图模型在选择新项之后(在AddItemCommand中调用了其方法)。但是,即使我将新项目添加到TextBox列表中,该视图仍无法找到Items,因为它尚不存在。

TextBox事件上关注Loaded Loaded事件可确保TextBox存在,因此尝试进行得到重点。这在这个简单的示例中有效,但在我的实际程序中无效。在我的程序中,当您在TextBox中输入内容,然后按添加按钮时,焦点将从文本框移开,然后该文本框调用一个单独的命令对项目进行排序。在排序过程中,一些文本框被移动,这将导致它们的Loaded事件被调用,然后该事件会从添加按钮中窃取焦点,因此其行为就好像从未按下添加按钮一样。

TextBox放在ListBox.ItemContainingGenerator.StatusChanged事件上:当列表框中的所选项目发生更改时,我将收听ItemContainingGenerator.StatusChanged事件。当列表框中的项目正在生成或完成生成时,将引发此事件。当它们完成生成后,我在所选项目(在视图模型中设置)内找到了TextBox并专注于此。此解决方案有效,但不一致。在我的某些列表框中,这不起作用,我不确定为什么。

hzcker 回答:在带有TextBoxes的ListBox中,如何关注添加的TextBox? 我尝试过的事情

我已经对您的代码进行了微小的更改..我认为它可以工作...

尝试一下:

 <ListBox x:Name="MyListBox"
        ItemsSource="{Binding Items}"
        SelectedItem="{Binding SelectedItem}"
        >
        <ListBox.ItemTemplate>
            <DataTemplate>
                <TextBox MinWidth="100" Text="{Binding Name}" Initialized="TextBoxElement_OnInitialized"/>
            </DataTemplate>
        </ListBox.ItemTemplate>
    </ListBox>

并在您的代码隐藏中:

 private int _textBoxCounter = 0;
        private void TextBoxElement_OnInitialized(object sender,EventArgs e)
        {
            if (_textBoxCounter < MyListBox.Items.Count)
            {
                Keyboard.Focus((IInputElement)sender);
                _textBoxCounter++;
            }

        }

这样,您可以确保在排序操作期间不会设置焦点

本文链接:https://www.f2er.com/3108254.html

大家都在问