Silverlight实例教程 - Navigation导航框架传递参数_Silverlight

上一篇学习了Silverlight Navigation导航框架URI映射机制,其中讨论到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映射机制中,我们曾经介绍过通过在App.xaml资源文件中设置MapperUri,从Home页面传递单一参数到About页面,其映射规则是:
 

 

<uriMapper:UriMapping Uri="/About/{parameter}" MappedUri="/Views/About.xaml?parameter={parameter}"/>


 

在源页面,通过NavigationService.Navigate方法对页面进行导航切换,其中附带需要传递的参数,

private void 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"

Silverlight实例教程 - Navigation导航框架传递参数_ 教程_02
 

 

 

 

根据以上介绍,如果需要传递多参数到目的页面,则需要添加新的地址映射规则,其中附带多个参数即可。例如添加规则:
 

<uriMapper:UriMapping Uri="/About/{name}&amp;{url}" MappedUri="/Views/About.xaml?name={name}&amp;url={url}"/>

使用NavigationService.Navigate方法对页面进行导航切换,其中附带需要传递的多个参数:
 

private void 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"
 

Silverlight实例教程 - Navigation导航框架传递参数_ 地址映射_03

 

 

读取“QueryString参数”方式传递参数值

Silverlight Navigation导航框架完成参数传递后,其目的页面,需要使用NavigationContext对象中的QueryString属性读取当前URI中包含的传递参数名称,以获取其参数值。其基本格式如下:
 

object parameter = this.NavigationContext.QueryString["parameter"];
 

以上面两个例程而言,其读取参数格式如下:

protected override void 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附带参数实例:
 

Silverlight实例教程 - Navigation导航框架传递参数_ 地址映射_04
 

 

 今天讲到这里,如果您有问题,欢迎留言讨论。

 源代码下载

 

 

Silverlight实例教程系列 - Silverlight Validation验证实例

Silverlight实例教程系列 - Silverlight Out-of-Browser实例

Silverlight实例教程系列 - Expression Blend实例中文教程

 

欢迎大家加入“专注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人