【WP7】页面之间数据交互

 在WP7开发中,经常需要在不同的页面切换,所以也会经常遇到数据在不同页面之间的传递问题,下面介绍几种数据传递的方法

  

1、页面之间传递数据(字符串)

    通过页面导航的Uri地址进行传递,导航到 Page2.xaml 页面

        string uriString = "/page2.xaml?parameter1=value1&parameter2=value2";
        Uri uri = new Uri(uriString, UriKind.Relative);
        this.NavigationService.Navigate(uri);

    字符串参数接在页面地址后面,格式为:    ?参数名1=参数值1&参数名2=参数值2

    在目标页面的 OnNavigatedTo() 函数中接受参数 

复制代码
        protected override void OnNavigatedTo(System.Windows.Navigation.NavigationEventArgs e)
        {
            if (this.NavigationContext.QueryString.Count > 0)
            {
                string value1, value2;
                this.NavigationContext.QueryString.TryGetValue("parameter1", out value1);
                this.NavigationContext.QueryString.TryGetValue("parameter1", out value2);
                
            }

            base.OnNavigatedTo(e);
        }
复制代码

   

2、页面之间传递对象

    一般的,我们不能在页面之间传递对象,页面之间对象传递通常采用全局对象来做,由于全局对象所有页面共享,所以也可以实现数据传递的功能

      - 定义全局对象

      在App.xaml.cs文件中的 App类 的构造函数前面添加静态属性 GlobalValue

    public partial class App : Application
    {
        public static String GlobalValue { get; set; }
    }

      然后页面之间通过 App.GlobalValue 引用并对其进行操作

    

3、关于别名的使用

    关于别名的使用(用的比较少),当应用程序的Uri地址导航比较多的时候,为了方便管理,我们可以通过别名的方式来访问

    别名的使用也是通过定义全局资源来实现的

    在App.xaml文件中添加命名空间

      xmlns:nav="clr-namespace:System.Windows.Navigation;assembly=Microsoft.Phone"

    然后添加资源:

        <Application.Resources>
            <nav:UriMapper x:Key="UriMapper">
                <nav:UriMapping Uri="Music" MappedUri="/Music.xaml"/>
                <nav:UriMapping Uri="Music/{song}" MappedUri="/Music.xaml?SongName={song}"/>
                <nav:UriMapping Uri="Music&amp;{song}&amp;{author}" MappedUri="/Music.xaml?SongName={song}&amp;SongAuthor={author}" />
            </nav:UriMapper>
        </Application.Resources>

    第一种为无参数别名导航

    第二种为带参数单个参数导航,{}里面的名字要完全一样

    第三种为多参数导航,参数与参数之间用 &amp; 连接(实际上就是&符号),注意:参数与别名之间也用 &amp; 连接,使用与第二种有点不同

    下面是使用:

    在xaml中使用

      在App.xaml.cs文件中的App类的构造函数中添加导航映射到 RootFrame 的 UriMapper

         this.RootFrame.UriMapper = Resources["UriMapper"] as UriMapper;

      然后就可以再Xaml文件中使用UriMapper资源了

     <HyperlinkButton Content="音乐1" Height="30" HorizontalAlignment="Left" Margin="68,40,0,0" Name="MusicshyperlinkButton1" VerticalAlignment="Top" Width="200" NavigateUri="Music" />

<
HyperlinkButton Content="音乐2" Height="30" HorizontalAlignment="Left" Margin="68,65,0,0" Name="MusicshyperlinkButton2" VerticalAlignment="Top" Width="200" NavigateUri="Music/借口" />
    <HyperlinkButton Content="音乐3" Height="30" HorizontalAlignment="Left" Margin="68,100,0,0" Name="MusicshyperlinkButton3" VerticalAlignment="Top" Width="200" NavigateUri="Musics&amp;借口&amp;周杰伦" />

    

    在C#代码中使用

      在C#代码中很少使用UriMapper,可以通过资源的方式访问,但是好像不能通过key来索引,只能通过index索引

            UriMapper uriMapper = App.Current.Resources["UriMapper"] as UriMapper;
            Uri uri = uriMapper.UriMappings[0].MappedUri;

 

posted @   bomo  阅读(376)  评论(0编辑  收藏  举报
努力加载评论中...
点击右上角即可分享
微信分享提示