当前位置: 首页 > news >正文

Windows Phone 7 不温不火学习之《页面导航》

用于Windows Phone 的SilverLight 提供了 PhoneApplicationFrame 和 PhoneApplicationPage类,这两个类是微软针对Silverlight for Windows Phone 另外封装的,它为导航提供了使得。

  PhoneApplicationPage 控件代表了内容相互分离的区段,一个应用程序可以有多个PhoneApplicationPage 。

  PhoneApplicationFrame 扮演了页面控件容器的角色,对页面之间的导航提供了便利,一个应用程序有一个独立的PhoneApplicationFrame。

  Windows Phone 7是通过 使用URI【通用资源标志符(Uniform Resouce Identifier )】映射进行页面导航的。下面通过 DEMO 来了解一下Windows Phone 7的各种导航的写法吧。

第一种通过使用NavigationService 进行导航控制,如下代码:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " /Layout/SecondPage.xaml " ,UriKind.Relative));

UriKind 是一个枚举类型,自带有三种类型,这里我们使用相对路径。

第二种通过直接使用控件自带功能,即使用微软的HyperLink控件,直接导航,代码如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < HyperlinkButtonContent = " 点转 " NavigateUri = " /Layout/SecondPage.xaml " Height = " 30 " HorizontalAlignment = " Left " Margin = " 101,68,0,0 " Name = " hyperlinkButton1 " VerticalAlignment = " Top " Width = " 200 " />

第三种我们可以为我们的URI路径起一个别名,然后在调用时调用别名即可,可以方便我们管理,使用步骤如下:

a).在App.xaml的文件上注册Windows.Navigation 命名空间,该空间位于Reference目录下的Microsoft.Phone组件,代码如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> xmlns:nav = " clr-namespace:System.Windows.Navigation;assembly=Microsoft.Phone "

b).为应用程序添加资源,代码如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < Application.Resources >
< nav:UriMapperx:Key = " UriMapper " >
< nav:UriMappingUri = " SecondPage " MappedUri = " /Layout/SecondPage.xaml " />

</ nav:UriMapper >
</ Application.Resources >

c).添加完成后,进入 App.xaml.cs 在它的构造函数里面为应用程序的RootFrame下所在的UriMapper 赋值,这用的话我们应用程序就可以通过它去映射我们传给它的URI 别名。代码如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> this .RootFrame.UriMapper = Resources[ " UriMapper " ] as UriMapper;

Tip:这里的Resources 是一个字典型数据,键值必须跟上面App.xaml 添加资源的UriMapper Key要相对应。

d).注册好别名之后,我们就可以在程序中如下使用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " SecondPage " ,UriKind.Relative));

或者在HyperLinkButton 中如下使用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < HyperlinkButtonContent = " 点转 " NavigateUri = " SecondPage " Height = " 30 " HorizontalAlignment = " Left " Margin = " 101,68,0,0 " Name = " hyperlinkButton1 " VerticalAlignment = " Top " Width = " 200 " />

好了,说完如何通过URI导航到指定Page 页面,下面来尝试一下如何通过URI导航传递数据吧。

做过Asp.Net 的童鞋相信对地址栏传值不陌生,比如我现在在博客园写文章的路径如下:

后面的“?”跟着的就是相关的参数或者要表达的某些请求,这种写法很好,又直接。做过WEB的又好理解,不过庆幸的是微软把这个非常棒的功能加入到Windows phone 7的页面传递中来,这真是一大另人兴奋的事,怎么样呢?就这样用:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " /Layout/SecondPage.xaml?opt=1 " ,UriKind.Relative));

或者

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < HyperlinkButtonContent = " 点转 " NavigateUri = " /Layout/SecondPage.xaml?opt=1 " Height = " 30 " HorizontalAlignment = " Left " Margin = " 101,68,0,0 " Name = " hyperlinkButton1 " VerticalAlignment = " Top " Width = " 200 " />

简单明了,不带一丝拖拉看来WEB开发人员进入Windows Phone 7开发也可以哟。。。呵呵~!!

我们刚才的缩写也是同样直接这种URI带参数的写法的,同样还是来到App.xaml页面,写法如下:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < Application.Resources >
< nav:UriMapperx:Key = " UriMapper " >
< nav:UriMappingUri = " SecondPage " MappedUri = " /Layout/SecondPage.xaml " />
< nav:UriMappingUri = " SecondPage/{content} " MappedUri = " /Layout/SecondPage.xaml?name={content} " />
</ nav:UriMapper >
</ Application.Resources >

这里要注意三点:

  • SecondPage/{content}与后面name={content}这两个content一定要相同
  • content 不可以写数字0,写数字0会报运行时错误。可以为数字1,但不可以为其他数字。为“1”时编译器解析正常,但为其他数字时虽不会报运行时错误,但编译器解析出错,不能够正确解析传进来的参数,会直接打印比如SecondPage/{111}在另外的页面就直接打印{111}。
  • MappedUri 后面“?”的查询字段区分大小写。

添加资源完成后,在页面使用如下方法即可调用缩写并传参数:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> NavigationService.Navigate( new Uri( " SecondPage/terry " ,UriKind.Relative));

试试效果吧,在页面中的按钮点击然后跳转到第二页,看会不会显示“terry”,如图:

获取参数跟Asp.net 差不多,见下方代码:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> if (NavigationContext.QueryString.Count > 0 )
{
UriTextBox.Text
= NavigationContext.QueryString[ " name " ].ToString();
}

  Windows Phone 7 的NavigationContext.QueryString 是不支持传递对象的,那么如果我们现在有个对象需要传递该如何实现呢?看了Jake Lin 老师的视频后才知道可以在App 里面定义一个对象属性,然后这个属性就可以提供全局访问。是不是我可以理解成这个属性其实也可以放在一个公用的静态类上呢?呵呵,下面看如何实现吧。

步骤一:

声明一个对象名为Model写下如何函数:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> public class Model
{
public string name{ get ; set ;}
public string file{ get ; set ;}
}

然后在App.xaml.cs 里面将Model 声明为一个公用的静态属性:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> public static Class.ModelMyAppModel{ get ; set ;}

余下的功夫就是为其赋值和取值的操作了,点击跳往下一页的按钮时,为App.Model 赋值。在第二页时取出App.Model的值,代码编写见下方:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> private void button1_Click( object sender,RoutedEventArgse)
{
App.MyAppModel
= new Class.Model{name = " terry " ,file = " my " };
NavigationService.Navigate(
new Uri( " SecondPage/terry " ,UriKind.Relative));
}

第二页Loaded完毕后:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> private void PhoneApplicationPage_Loaded( object sender,RoutedEventArgse)
{
if (NavigationContext.QueryString.Count > 0 )
{
UriTextBox.Text
= NavigationContext.QueryString[ " name " ].ToString();
}
Class.Modelmodel
= App.MyAppModel;

Debug.WriteLine(model.name
+ " ===>>> " + model.file);
}

见输出日志信息:

我们还可以通过别名传参的方法,动态的指定页面跳转,先看看界面:

页面上有三个单选按钮,然后工程中对应有三个页面:

选择后,点击按钮将会通过下标动态跳转到不同的页面,代码编写看下方。

首先,App.xaml的资源添加:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> < Application.Resources >
< nav:UriMapperx:Key = " UriMapper " >
< nav:UriMappingUri = " SecondPage " MappedUri = " /Layout/SecondPage.xaml " />
< nav:UriMappingUri = " SecondPage/{content} " MappedUri = " /Layout/SecondPage.xaml?name={content} " />
< nav:UriMappingUri = " page/{number} " MappedUri = " /Layout/Page{number}.xaml " />
</ nav:UriMapper >
</ Application.Resources >

然后,在主页上声明一个全局索引,接着编写如下代码,即可完成:

<!--<br /><br />Code highlighting produced by Actipro CodeHighlighter (freeware)<br />http://www.CodeHighlighter.com/<br /><br />--> private void firstRb_Checked( object sender,RoutedEventArgse)
{
index
= 1 ;
}

private void secondRb_Checked( object sender,RoutedEventArgse)
{
index
= 2 ;
}

private void threeRb_Checked( object sender,RoutedEventArgse)
{
index
= 3 ;
}

private void chooseButton_Click( object sender,RoutedEventArgse)
{
NavigationService.Navigate(
new Uri( " page/ " + index,UriKind.Relative));
}

页面导航和数据传递的课程学习完毕到这里先,如果你觉得对你有帮助,别忘了推荐一下,谢谢。

------点击发布,才记起忘了发源码:导航DEMO

相关文章:

  • 我的ipad应用备份
  • 我又回来了
  • windows向ubuntu过渡之常用软件安装
  • java.util.ConcurrentModificationException 异常
  • windows和linux的协议栈驱动
  • vmware的vmnet-概念的解说
  • typeScript.webpackreact的正确版quickStart
  • vmware的vmnet-感官和视觉上的效果
  • 学习笔记:树分治
  • vmware的vmnet-有机会还要看源码
  • Python中递归的最大次数
  • vmware的vmnet-理解全景后解答两个问题
  • vmware的vmnet-组网,升级和应用
  • lintcode:形状工厂
  • 深入挖掘Molehill API的一些特征
  • [LeetCode] Wiggle Sort
  • Angular 响应式表单 基础例子
  • Java深入 - 深入理解Java集合
  • jquery cookie
  • JS学习笔记——闭包
  • Leetcode 27 Remove Element
  • MySQL的数据类型
  • nodejs调试方法
  • node-sass 安装卡在 node scripts/install.js 解决办法
  • php的插入排序,通过双层for循环
  • socket.io+express实现聊天室的思考(三)
  • vue-router的history模式发布配置
  • 从地狱到天堂,Node 回调向 async/await 转变
  • 验证码识别技术——15分钟带你突破各种复杂不定长验证码
  • 数据可视化之下发图实践
  • 小白应该如何快速入门阿里云服务器,新手使用ECS的方法 ...
  • ​HTTP与HTTPS:网络通信的安全卫士
  • ​猴子吃桃问题:每天都吃了前一天剩下的一半多一个。
  • #经典论文 异质山坡的物理模型 2 有效导水率
  • (1)bark-ml
  • (分布式缓存)Redis分片集群
  • (三十五)大数据实战——Superset可视化平台搭建
  • (深入.Net平台的软件系统分层开发).第一章.上机练习.20170424
  • (一)插入排序
  • (转)Linux下编译安装log4cxx
  • .dwp和.webpart的区别
  • .NET 4 并行(多核)“.NET研究”编程系列之二 从Task开始
  • .NET Core使用NPOI导出复杂,美观的Excel详解
  • .net 发送邮件
  • .Net程序猿乐Android发展---(10)框架布局FrameLayout
  • .Net高阶异常处理第二篇~~ dump进阶之MiniDumpWriter
  • .NET中GET与SET的用法
  • // an array of int
  • @ModelAttribute 注解
  • @modelattribute注解用postman测试怎么传参_接口测试之问题挖掘
  • @RequestParam @RequestBody @PathVariable 等参数绑定注解详解
  • [ 代码审计篇 ] 代码审计案例详解(一) SQL注入代码审计案例
  • [2015][note]基于薄向列液晶层的可调谐THz fishnet超材料快速开关——
  • [20190113]四校联考
  • [ASP.NET 控件实作 Day7] 设定工具箱的控件图标