Navigation导航框架传递参数

最后更新于:2022-04-01 14:21:19

![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-03-18_56eb67c868925.jpg) 上一篇学习了[Silverlight Navigation导航框架URI映射机制](http://www.cnblogs.com/jv9/archive/2011/08/09/2131663.html),其中讨论到Silverlight Navigation导航框架传递参数的问题。说起导航框架页面间传递参数,是最常用开发技巧之一。本篇将详细讲解Silverlight Navigation导航传参方法。 传统Web应用中,由于普通Web页面属于无状态类型页面,所以各页面间传递参数经常使用Cookies,Session或者ViewState技术传递数据。另外,也会经常使用QueryString参数的方式,附加要传递的参数到当前URI链接,共享参数在服务器端和客户端之间。相比而言,Silverlight作为富客户端技术,其应用页面属于有状态类型页面,简单的理解,在Silverlight客户端定义的变量其内容都会被保存在客户端内存中,当前页面状态也将被保存。换句话说,Silverlight页面间传递参数可以定义全局应用级变量进行参数传递,但是这种方式会增加应用内存开支,降低应用运行效率,所以不推荐使用。而Silverlight应用另外一种传递参数的方法与传统Web应用传递参数方法类似,使用 “QueryString参数”的方式实现页面间参数传递。 **“QueryString参数”方式传递参数基础格式** “QueryString参数”方式传递参数,在传统Web应用传参中经常用到,Silverlight仍旧使用传统格式进行URI参数传递操作,其格式如下: /Views/Page.xaml?Parameter=Value 以上链接中,Page.xaml是一个Silverlight客户端应用页面,而需要传递的参数名称为“Parameter”,其参数值为“Value”。通过使用"?"连接页面名称和附带参数,目的页面通过指定API可以获取到附带的参数名称和参数值。 页面间,多参数传递格式如下: /Views/Page.xaml?Parameter1=Value1&Parameter2=Value2 以上链接中使用"&"符号实现在URI中附加多参数,以达到多参数传递目的。 由上面可以看出,“QueryString参数”方式传递参数主要是通过URI,传递方法则与Silverlight导航框架URI地址映射有着密切的联系。 **“QueryString参数”方式传递参数方法** 在上一篇[URI映射机制](http://www.cnblogs.com/jv9/archive/2011/08/09/2131663.html)中,我们曾经介绍过通过在App.xaml资源文件中设置MapperUri,从Home页面传递单一参数到About页面,其映射规则是: <uriMapper:UriMapping Uri="/About/{parameter}" MappedUri="/Views/About.xaml?parameter={parameter}"/> 在源页面,通过NavigationService.Navigate方法对页面进行导航切换,其中附带需要传递的参数, ~~~ privatevoid btSend_Click(object sender, RoutedEventArgs e) { this.NavigationService.Navigate(new Uri(String.Format("/About/"+ txtQueryString.Text.Trim()), UriKind.Relative)); } ~~~ 在Navigation导航框架运行时,在浏览器中URI地址格式为: http://localhost:49750/SilverlightNavigationDemoTestPage.aspx#/About/SilverlightChina 通过URI地址映射解析,其实际地址将指向到"/Views/About.xaml?parameter=SilverlightChina", ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-03-18_56eb67d09fb39.gif) 根据以上介绍,如果需要传递多参数到目的页面,则需要添加新的地址映射规则,其中附带多个参数即可。例如添加规则: <uriMapper:UriMappingUri="/About/{name}&amp;{url}" MappedUri="/Views/About.xaml?name={name}&amp;url={url}"/> 使用NavigationService.Navigate方法对页面进行导航切换,其中附带需要传递的多个参数: ~~~ privatevoid btSendMultiple_Click(object sender, RoutedEventArgs e) { this.NavigationService.Navigate(new Uri(String.Format("/About/"+ txtNameString.Text.Trim()+"&"+ txtURLString.Text.Trim()), UriKind.Relative)); } ~~~ 在映射规则中,使用{name}和{url} 作为URI通用符,两者使用"&amp"是“&”符号的HTML表示方法。 在Navigation导航框架运行时,在浏览器中URI地址格式为: http://localhost:49750/SilverlightNavigationDemoTestPage.aspx#/About/%E9%93%B6%E5%85%89%E4%B8%AD%E5%9B%BD%E7%BD%91&SilverlightChina.Net 通过URI地址映射解析,其实际地址将指向到"/Views/About.xaml?name=%E9%93%B6%E5%85%89%E4%B8%AD%E5%9B%BD%E7%BD%91&url=SilverlightChina.Net" ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-03-18_56eb67d0aee2e.gif) **读取“QueryString参数”方式传递参数值** Silverlight Navigation导航框架完成参数传递后,其目的页面,需要使用NavigationContext对象中的QueryString属性读取当前URI中包含的传递参数名称,以获取其参数值。其基本格式如下: object parameter = this.NavigationContext.QueryString["parameter"]; 以上面两个例程而言,其读取参数格式如下: ~~~ protectedoverridevoid OnNavigatedTo(NavigationEventArgs e) { if (this.NavigationContext.QueryString.ContainsKey("parameter")) { tbReceiveParameter.Text ="接收到的传递参数值:"+this.NavigationContext.QueryString["parameter"]; } else { tbReceiveParameter.Text ="接收参数1: "+this.NavigationContext.QueryString["name"]+" 接收参数2:"+this.NavigationContext.QueryString["url"]; } } ~~~ 在使用NavigationContext读取参数时,有以下两点需要注意: - 读取参数前需要检测参数名称是否存在,如果NavigationContext.QueryString中不存在需要获取的参数名称,则应用会出现异常;而参数值允许为空,如果参数值空,则返回Null到页面。常用检测代码如下:NavigationContext.QueryString.ContainsKey(paramName) - 参数赋值前需要进行参数类型转换,因为参数传递是以字符串形式传递,而页面赋值时则需要根据需求进行值类型转换,否则应用会出现异常;常用类型转换代码如下:int.TryParse(NavigationContext.QueryString[paramName], out paramValue) 最后,从MSDN转一个URI地址映射解析匹配对照表,其中包括URI附带参数实例: ![](https://docs.gechiui.com/gc-content/uploads/sites/kancloud/2016-03-18_56eb67d0bfcb0.gif) 今天讲到这里,如果您有问题,欢迎留言讨论。 [源代码下载](http://www.silverlightchina.net/uploads/soft/110809/1-110P91IU3.rar) [Silverlight实例教程系列 - Silverlight Validation验证实例](http://silverlightchina.net/html/zhuantixilie/getstart/2010/0924/2035.html) [Silverlight实例教程系列 - Silverlight Out-of-Browser实例](http://silverlightchina.net/html/zhuantixilie/getstart/2010/0809/1709.html) [Silverlight实例教程系列 - Expression Blend实例中文教程](http://silverlightchina.net/html/zhuantixilie/getstart/2010/0409/978.html) 欢迎大家加入“专注Silverlight”QQ技术群,欢迎大家加入一起学习讨论Silverlight&WPF&Widnows Phone开发技术。 22308706(一群) 超级群500人 37891947(二群) 超级群500人 100844510(三群) 高级群200人 32679922(四群) 超级群500人 23413513(五群) 高级群200人 32679955(六群) 超级群500人 61267622(七群) 超级群500人 88585140(八群) 超级群500人 128043302(九群 企业应用开发推荐群) 高级群200人 101364438(十群) 超级群500人 68435160(十一群 企业应用开发推荐群)超级群500人
';