Использование кнопки для перехода на другую страницу в NavigationWindow
Я пытаюсь использовать инфраструктуру команд навигации в WPF для перемещения между страницами в приложении WPF (рабочий стол; не XBAP или Silverlight).
Я считаю, что у меня все настроено правильно, но не работает. Я создаю и запускаю без ошибок, я не получаю никаких ошибок привязки в окне вывода, но моя кнопка навигации отключена.
Вот app.xaml для примера приложения:
<Application x:Class="Navigation.App"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
StartupUri="First.xaml">
</Application>
Обратите внимание, что StartupUri указывает на First.xaml. First.xaml - это страница. WPF автоматически размещает мою страницу в NavigationWindow. Вот первый.xaml:
<Page x:Class="Navigation.First"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
Title="First">
<Grid>
<Button
CommandParameter="/Second.xaml"
CommandTarget="{Binding RelativeSource=
{RelativeSource
FindAncestor,
AncestorType={x:Type NavigationWindow}}}"
Command="NavigationCommands.GoToPage"
Content="Go!"/>
</Grid>
</Page>
CommandTarget кнопки установлен в NavigationWindow. Команда - GoToPage, а страница - /Second.xaml. Я попытался установить CommandTarget для содержащей страницы, CommandParameter для "Second.xaml" (First.xaml и Second.xaml оба находятся в корне решения), и я попытался оставить CommandTarget пустым. Я также попытался установить Путь к Привязке к различным общедоступным свойствам, связанным с навигацией, в NavigationWindow. Пока ничего не получалось.
Что мне здесь не хватает? Я действительно не хочу делать свою навигацию в коде.
Разъяснение.
Если вместо кнопки я использую гиперссылку:
<Grid>
<TextBlock>
<Hyperlink
NavigateUri="Second.xaml">Go!
</Hyperlink>
</TextBlock>
</Grid>
все работает как положено. Тем не менее, мои требования к пользовательскому интерфейсу означают, что использование гиперссылки прямо. Мне нужна большая жирная кнопка, чтобы люди нажимали. Вот почему я хочу использовать кнопку для навигации. Я просто хочу знать, как заставить Баттон предоставлять те же возможности, что и Гиперссылка в этом случае.
4 ответа
Согласно документации, только DocumentViewer
а также FlowDocumentViewer
реализовать эту команду специально. Вам нужно будет либо найти команду для навигации, которая NavigationWindow
реализует, или настроить CommandBinding
для этой команды и справиться с этим самостоятельно.
В XAML:
<Button Command="{x:Static Views:Commands.NavigateHelp}" Content="Help"/>
В представлениях (у нас есть Commands.cs
файл, который содержит все это):
public static RoutedCommand NavigateHelp = new RoutedCommand();
В consttructor Page вы можете соединить два:
CommandBindings.Add(new CommandBinding(Commands.NavigateHelp, NavigateHelpExecute));
NavigateHelpExecute может быть в коде позади (что мы и делаем), подключаться к обработчику событий ViewModel или как угодно. Прелесть этого в том, что вы можете отключить другую навигацию следующим образом:
CommandBindings.Add(new CommandBinding(NavigationCommands.Refresh, null));
Надеюсь это поможет.
Вы хотите использовать NavigationService
вашей NavigationWindow
следующее:
XAML:
<Button HorizontalAlignment="Right" Name="continueButton" Width="75" Margin="0,0,8,11" Height="23" VerticalAlignment="Bottom" Click="continueButton_Click">
Continue
</Button>
C#:
private void continueButton_Click(object sender, RoutedEventArgs e)
{
this.NavigationService.GoForward();
//or
this.NavigationService.Navigate("Second.xaml")
}
С любым из этого вы можете использовать использование this
Я только покажу NavigationService
здесь для ясности
public class NavigateButton : Button
{
public Uri NavigateUri { get; set; }
public NavigateButton()
{
Click += NavigateButton_Click;
}
void NavigateButton_Click(object sender, System.Windows.RoutedEventArgs e)
{
var navigationService = NavigationService.GetNavigationService(this);
if (navigationService != null)
navigationService.Navigate(NavigateUri);
}
}
И тогда вы можете поместить следующее в ваш xaml:
<local:NavigateButton Content="NavigateButton" NavigateUri="Page2.xaml"/>
Тогда вам все еще не нужен код за вашими страницами, и вам не нужно добавлять команды в вашу модель представления.