Uwp导航示例并专注于控制

时间:2015-11-09 13:08:40

标签: c# xaml focus windows-10 win-universal-app

我使用uwp navigation example作为我的应用程序导航的示例。我需要将重点放在TextBox上。我在uwp navigation example上试一试。对于BasicPage,我添加以下代码:

   <StackPanel Orientation="Vertical">
        <TextBox x:Name="Test" />
        <TextBox x:Name="Test1" />
    </StackPanel>

    public BasicPage()
    {
        this.InitializeComponent();
        this.Loaded += BasicPage_Loaded;
    }

    private void BasicPage_Loaded(object sender, RoutedEventArgs e)
    {
        Test1.Focus(FocusState.Programmatic);
    }

Test1没有得到关注。我在“普通”Windows通用应用程序中尝试此代码 - 这是工作。你有什么建议吗?

2 个答案:

答案 0 :(得分:9)

这是因为在调用Test1.Focus之后,在其他地方调用了Focus函数。

在AppShell.xaml.cs中,您可以找到以下代码:

private void OnNavigatedToPage(object sender, NavigationEventArgs e)
{
    // After a successful navigation set keyboard focus to the loaded page
    if (e.Content is Page && e.Content != null)
    {
        var control = (Page)e.Content;
        control.Loaded += Page_Loaded;
    }
}

private void Page_Loaded(object sender, RoutedEventArgs e)
{
    ((Page)sender).Focus(FocusState.Programmatic);
    ((Page)sender).Loaded -= Page_Loaded;
    this.CheckTogglePaneButtonSizeChanged();
}

上述代码表示当您导航到某个页面时,它会订阅页面加载的事件并将焦点设置在页面上。

您的代码在页面本身中订阅页面加载的事件。您的代码将在AppShell中的Page_Loaded函数之前执行。所以你没有得到你想要的东西。

因此,如果您只是在Page_Loaded函数中注释掉((Page)sender).Focus(FocusState.Programmatic);。你会得到你想要的。我不确定该行的确切目的是什么。但一切似乎都很好。

如果您在注释掉该行后发现错误,我们也可以解决它。加载事件后,在LayoutUpdated事件中调用焦点函数一次。

public sealed partial class BasicPage : Page
{
    bool bAfterLoaded = false;
    public BasicPage()
    {
        this.InitializeComponent();
        this.Loaded += BasicPage_Loaded;
        this.LayoutUpdated += BasicPage_LayoutUpdated;
    }

    private void BasicPage_LayoutUpdated(object sender, object e)
    {
        if (bAfterLoaded)
        {
            Test1.Focus(FocusState.Programmatic);
            bAfterLoaded = !bAfterLoaded;
        }
    }

    private void BasicPage_Loaded(object sender, RoutedEventArgs e)
    {
        bAfterLoaded = !bAfterLoaded;
    }
}

希望这可以帮到你。

答案 1 :(得分:0)

如果要以编程方式聚焦文本框。防止键盘显示,因此layoutupdate事件不会触发。你可以做点什么 然后在page_loaded事件中执行Test1.Focus(FocusState.Programmatic);