SL学习笔记 -- Navigation Framework
推荐看Tim Heuer的视频:http://silverlight.net/learn/videos/silverlight-videos/navigation-framework/
新建SL应用程序后,首先引入System.Windows.Controls和System.Windows.Controls.Navigation。
在App中引用命名空间:
xmlns:navcore="clr-namespace:System.Windows.Navigation;assembly=System.Windows.Controls.Navigation"
添加映射规则:
<navcore:UriMapper x:Key="uriMapper" >
<navcore:UriMapping Uri="Home" MappedUri="/Views/HomePage.xaml" />
</navcore:UriMapper>
然后在MainPage中引用命名空间:
xmlns:navigation="clr-namespace:System.Windows.Controls;assembly=System.Windows.Controls.Navigation"
添加导航按钮:
<HyperlinkButton Tag="Home" Click="NavigateButton_Click" Content="Home" FontSize="24" />
并创建事件:
private void NavigateButton_Click(object sender, RoutedEventArgs e)
{
HyperlinkButton btn = sender as HyperlinkButton;
string url = btn.Tag.ToString();
this.MainFrame.Navigate(new Uri(url, UriKind.Relative));
}
添加导航框架:
<navigation:Frame x:Name="MainFrame" UriMapper="{StaticResource uriMapper}" HorizontalAlignment="Stretch" Margin="20" Source="Home" />
PS:Tim Heuer那里下载的代码不能运行,必须添加 UriMapper="{StaticResource uriMapper}" .这个问题困扰了我好久,还好视频里面的评论有人提到,我才解决。
在SL项目中添加文件夹View,然后添加HomePage.xaml。
作 者:doku
出 处:http://www.cnblogs.com/kulong995/
关于作者:喜欢编程,喜欢美食,专注于.NET项目开发。
版权声明:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文链接。
声援博主:如果您觉得文章对您有帮助,可以点击文章右下角【推荐】一下。您的鼓励是作者坚持原创和持续写作的最大动力!