zoukankan      html  css  js  c++  java
  • windows phone URI映射

    UriMapping用于在一个较短的URI和你项目中的xaml页的完整路径定义一个映射(别名)。通过使用别名URI,开发者可以在不改变导航代码的情况下来改变一个项目的内部结构。该机制还提供了一个简单的方法以参数在页面之间传递数据,并可以导航到使用参数动态创建的页面。

    一、代码映射URI

    主要操作时对app.xaml.cs中对RootFrame的属性UriMapper进行赋值。

    在app.xaml.cs中添加方法

    /// <summary>
            /// 创建UriMapping对象
            /// </summary>
            /// <param name="uri">请求的uri</param>
            /// <param name="mappeduri">导航到的uri</param>
            /// <returns></returns>
            public UriMapping CreateUriMapping(string uri, string mappeduri)
            {
                return new UriMapping() { 
                    MappedUri=new Uri(mappeduri,UriKind.Relative),
                    Uri=new Uri(uri,UriKind.Relative)
                };
            }

    并在InitializePhoneApplication()方法初始化后对RootFrame的UriMapper属性赋值

    UriMapper mapper = new UriMapper();
                //简单的映射
                mapper.UriMappings.Add(CreateUriMapping("Test", "/TestPage.xaml"));
                //传递参数
                mapper.UriMappings.Add(CreateUriMapping("TestParam/{value1}/{value2}", "/TestPageParam.xaml?id={value1}&name={value2}"));
                //导航到使用参数动态创建的页面 NavigationService.Navigate(new Uri("Test1",UriKind.Relative)) 访问TestPage1.xaml
                mapper.UriMappings.Add(CreateUriMapping("Test{num}", "/TestPage{num}.xaml"));
                RootFrame.UriMapper = new UriMapper();
                RootFrame.UriMapper = mapper;

    二、使用XAML映射URI

    首先要添加命名空间

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

    在<Application.Resources>中添加如下代码

    <appnavigation:UriMapper x:Key="UriMapper">
                <appnavigation:UriMapper.UriMappings>
                    <appnavigation:UriMapping Uri="Test" MappedUri="/TestPage.xaml" />
                    <!-- 传递参数是,如传递多个参数时,许将 & 转义为 &amp; -->
                    <appnavigation:UriMapping Uri="TestParam/{value1}/{value2}" MappedUri="/TestPageParam.xaml?id={value1}&amp;name={value2}"/>
                    <appnavigation:UriMapping Uri="Test{num}" MappedUri="/TestPage{num}xaml"/>
                </appnavigation:UriMapper.UriMappings>
            </appnavigation:UriMapper>

    最后在app的构造函数中对RootFrame的UriMapper属性赋值,InitializePhoneApplication()方法后

    RootFrame.UriMapper = Resources["UriMapper"] as UriMapper;
  • 相关阅读:
    分库分表(1) --- 理论
    Elasticsearch(10) --- 内置分词器、中文分词器
    Elasticsearch(9) --- 聚合查询(Bucket聚合)
    Elasticsearch(8) --- 聚合查询(Metric聚合)
    Elasticsearch(7) --- 复合查询
    Elasticsearch(6) --- Query查询和Filter查询
    Elasticsearch(5) --- 基本命令(集群相关命令、索引CRUD命令、文档CRUD命令)
    第二周 Word版面设计
    第六周 Word目录和索引
    第五周 Word注释与交叉引用
  • 原文地址:https://www.cnblogs.com/my-tzc/p/3500868.html
Copyright © 2011-2022 走看看