2

我正在开发 Windows 10 UWP 应用程序,并且正在使用Template10 library中的空白模板。我能够毫无问题地让汉堡菜单正常工作。该应用程序要求用户先登录,然后进入应用程序的“主页”。我想在他们登录后在汉堡菜单底部显示用户的用户 ID 作为辅助按钮,或者如果他们没有登录(或注销)则显示登录选项。

这是应该显示用户 ID 的辅助按钮的 XAML:

<controls:HamburgerButtonInfo>
            <StackPanel Orientation="Horizontal" VerticalAlignment="Center">
                <SymbolIcon Symbol="Contact"  Width="48" Height="48"  />
                <TextBlock Name="Username" Margin="12, 0, 0, 0" VerticalAlignment="Center"/>
            </StackPanel>
</controls:HamburgerButtonInfo>

代码隐藏只是启用汉堡菜单外壳的默认构造函数,其中添加了代码以显示用户名。

public Shell(NavigationService navigationService)
    {
        this.InitializeComponent();
        Menu.NavigationService = navigationService;
        if(user logged in)
        {
            Username.Text = Username;
        }
        else
        {
            Username.Text = "login";
        }
    }

该代码的部分工作原理是即使在用户登录后它也会显示“登录”。仅当应用程序暂停/恢复或退出/重新启动时才会显示用户名。如何确保用户一登录,汉堡菜单外壳中的辅助按钮就会更新,而无需重新启动/恢复应用程序?

4

1 回答 1

2

由于您使用的是 Template10,建议您看一下 Model View View Model pattern (Channel9 介绍视频)

使用此模式,您可以删除部分后面的代码,并且从 XAML 级别,您可以执行以下操作:

<TextBlock Name="Username" Text="{Binding UserDataContext.LoginString}" Margin="12, 0, 0, 0" VerticalAlignment="Center"/>

UserDataContext是对 ViewModel 类的引用,该类公开了一些属性,例如LoginString,可能是这样的:

public string LoginString
{
    get
    {
        return _loginString;
    }

    set
    {
        if (_loginString == value)
        {
            return;
        }

        _loginString = value;
        RaisePropertyChanged(() => LoginString);
    }
}

每次从您的代码中,您将通过其属性更改 _loginString 的值,您的 TextBlock 将被通知并且其Text将被更新。这样,您不必在 Shell 构造函数中更改 HamburgerButtonInfo 文本,而是在您的 UserDataContext 中的任何位置。

请注意,这RaisePropertyChanged是来自MVVM Light Toolkit

于 2015-12-28T12:55:35.243 回答