zoukankan      html  css  js  c++  java
  • 【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;
  • 相关阅读:
    webpack学习笔记(五)
    webpack学习笔记(四)
    webpack学习笔记(三)
    directives 自定义指令
    css面试--基础
    css面试--H5移动端
    vue watch和computed的使用场景
    JS继承的实现方式
    js面试--ajax与性能优化
    js面试--概念
  • 原文地址:https://www.cnblogs.com/bomo/p/2755740.html
Copyright © 2011-2022 走看看