本文翻译自CodeProject文章:https://www.codeproject.com/Articles/1226447/Xamarin-Notes-Xamarin-Forms-Pages

转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。

引言

在之前的章节,我讲解了如何为Android或者iOS应用程序开发准备环境以及Layout布局的一些基本概念。

在本章中,我将开始在Xamarin.Forms中展示我们页面的结构。

Xamarin.Forms基于Page页面的概念,我们可以使用XAML创建一个应用程序来设计我们的页面以及后台的C#代码。

我们有五种不同的页面类型:ContentPage、NavigationPage、TabbedPage、CarouselPage以及MasterDetailPage。

在Visual Studio 2017中创建一个新工程,我们选择File/New/project

之后会弹出一个窗口以供我们选择Visual C#/Cross-Platform,此处.NET Framework默认将会是最新版本,在我这里Framework的版本号是4.6.2

接下来一个窗口将显示出来用做选择是一个空白工程还是一个Master-Detail模式的工程(它集成了MVVM模式的应用)。

该模板允许你选择想要的内容,包括你想要基于的平台,以及具体的代码共享策略。

在过去,我们看到的界面长这个样子:

但是在最近更新的版本Visual Studio 2015 15.5.2中,我们将看不到在“代码共享策略”一栏有PCL(可移植类库)的选项,它被.NET Standard所取代。

让我们来理解与之相关的一些概念。

PCL或者说可移植类库是一组类库,该类库以一组具有相同API的平台为目标的类库。更多详细信息,请参见此链接

.NET Standard:它是一组“标准”API而不是一个平台。这里我们将不谈论任何平台,它仅仅是一个标准(当前版本2.0),你的代码可以在支持它的所有平台上运行。在2017年11月,.NET Standard进入了Xamarin.Forms的项目模板。

因此将支持的目标从PCL转向.NET Standard,所带来的不同仅仅是命名空间的指向被标准化为另外一种不同的方式。

.NET Standard 2.0的新版本致力于通过各种平台共享代码,现在Xamarin.Forms通过跨平台应用程序向导引入它,它将默认使用PackageReference。我们来看看新窗口的样子:

以下是Github上关于.NET Standard的更多信息:

这是另外一篇很不错的文章,解释相关话题:

  • https://blog.xamarin.com/building-xamarin-forms-apps-net-standard/

    • UI结构
    • 你所看到的第一页面就是这一个,那么什么是页面(Page)?它可以包含什么?
    • 页面是一个主容器,在我们的示例中,它是一个ContentPage类型的页面。
    • 在该Page页面中,我们将添加一个Layout布局,在本示例中我们用的是StackLayout,在该StackLayout中间,我们将添加一些view视图。这些视图是一组控件,在本示例中,我们用到的是:一个Label标签,一个Entry(输入文本)以及一个Button按钮。
    • Xamarin.Forms提供了许多可用的页面,以允许提出各种不同的导航体验。为了精确的定义什么是一个Xamarin.Forms.Page的示例,官方的文档给出了一个清晰而简明的定义。
    • 这个链接中提到的那样:
    • “页面是占据屏幕大部分或全部并包含单个子的视觉元素。一个页面代表Windows中的一个视图控制器,一个Windows中的一个页面,就像Android上的一个Activity,但不是一个活动的Activity。”
    • 没有任何特定功能的最简单页面,用于开始一个空白页面的模板。

页面

1. ContentPage

<!--这是 XAML 部分--><? xml version = "1.0" encoding = "utf-8"?><ContentPage xmlns = "http://xamarin.com/schemas/2014/forms"
xmlns: x = "http://schemas.microsoft.com/winfx/2009/xaml"
x: Class = "Sample.MyContentPage"
Title = "ContentPage Presentation" Padding = "10"> <StackLayout><Label Text = "Welcome to Xamarin.Forms !" /></StackLayout></ContentPage>

ContentPage继承自TemplatedPage,这是Xamarin.Forms.dll中的基类:

要添加新的ContentPage,我们选择:New Item/ContentPage.xaml

NavigationPage

它是一种可以容纳多个页面的页面,但只显示一个页面,并提供在它们之间进行导航的功能。

在我们的示例中,我们实例化了一个新的NavigationPage对象,在其构造器中,我们指定了其显示的第一个页面。

NavigationPage继承自Page类。

当我们需要从一个页面导航到另一个页面时,我们可以有一组函数可以调用。

如果我们希望在一个按钮动作事件中跳转到另一个页面,我们使用以下代码:

Navigation.PushAsync(new AboutPage())

或者该方法的异步版本:

Navigation.PushModalAsync(new AboutPage());

我们可以通过使用以下方法返回到前一个页面:Navigation.PopAsync();或者Navigation.PopModalAsync();

其它可以使用的方法如下:

Navigation.PopToRootAsync();从导航堆栈中弹出所有堆栈的页面,除了根Xamarin.Forms.Page页面。

我们可以在XAML部分使用导航功能,如下所示:

<!--这是XAML部分-->
<NavigationPage Title="Schedule" Icon="schedule.png">
<x:Arguments>
<local:MyPage1 />
</x:Arguments>
</NavigationPage>

在此示例中,我们创建一个Page,设置其标题为Schedule,并指定一个“schedule.png”的图标,我们页面的内容在内部的MyPage1中,那是一个ContentView,而不是一个ContentPage

邀请你在如下链接了解更多相关信息:

TabbedPage

如同该类型的名称一样,它类似于Web或Pivot控件中的Tab,允许显示包含多个选项卡的页面。

我们通过C#代码创建了一个TabbedPage

<TabbedPage xmlns="http://xamarin.com/schemas/2014/forms"

xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"

xmlns:mypages="clr-namespace:MyApp.Pages;assembly=MyApp"  

            x:Class="MyApp.Pages.Navigation">
<TabbedPage.Children>
<mypages:Page1 Title="Page 1"/>
<mypages:Page2 Title="Page 2"/>
<mypages:Page3 Title="Page 3"/>
</TabbedPage.Children>
</TabbedPage>

CarouselPage

该页面使用滑动手势在页面之间导航。

更多细节:

我们通过C#代码创建了一个CarouselPage

public partial class App : Application
{
public App ()
{
InitializeComponent(); MainPage = new MasterProject.Views.MasterPage();
CarouselPage carouselPage = new CarouselPage();
carouselPage.Children.Add(new MainPage());
carouselPage.Children.Add(new Page1());
carouselPage.Children.Add(new Page2());
MainPage = carouselPage;
}

 同样我们也可以使用以下代码通过XAML添加一个CarouselPage: 

<?xml version="1.0" encoding="UTF-8"?>
<CarouselPage xmlns="http://xamarin.com/schemas/2014/forms" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" xmlns:local="clr-namespace:NogginXamarinFormSample;assembly=CarouselPage" x:Class="CarouselPage.Sample">
<CarouselPage.Children>
<local:MyPage1 />
<local:MyPage2 />
<local:MyPage3 />
</CarouselPage.Children>
</CarouselPage>

在我们的示例中,后面的代码将是这样的:

public partial class CarouselPage : CarouselPage {
}

MasterDetailPage

Xamarin.Forms MasterDetailPage是一个管理两个相关信息页面的页面 - 一个显示项目的主记录页面,以及一个显示主记录页面上单个项目详细信息的详细信息页面。本文介绍如何使用MasterDetailPage和在其信息页面之间导航。”更多详细信息,请查看此链接

  

因此,Master Detail Page容器拥有两个页面,一个是主记录页面,另一个是详细信息页面。主记录页面将包含菜单列表,详细信息页面将显示详细信息并将链接返回主记录页面,想法很简单,如果你有任何按钮或选项在菜单中显示它但你想在一开始隐藏它们,以保持良好的UI体验。

我们将使用以下XAML代码对其进行定义:

<MasterDetailPage.Master >
<ContentPage Padding="10" BackgroundColor="Gray"
Title="Master" Icon="hamburger.png">
<ContentPage.Content>
<StackLayout Margin="5,30,5,5">
<Label Text="Master Page">
</Label>
<Button x:Name="goToPage1"
Text="Go to Page 1" BackgroundColor="Yellow"
Clicked="goToPage1_Clicked"></Button>
<Button x:Name="goToPage2"
Text="Go to Page 2" BackgroundColor="Red"
Clicked="goToPage2_Clicked"></Button>
<Button x:Name="goToPage3"
Text="Go to Page 3" BackgroundColor="Green"
Clicked="goToPage3_Clicked"></Button>
</StackLayout>
</ContentPage.Content>
</ContentPage>
</MasterDetailPage.Master>
<MasterDetailPage.Detail>
<ContentPage Padding="10">
<ContentPage.Content>
<StackLayout Margin="5,30,5,5">
<Label Text="Detail Page">
</Label>
</StackLayout>
</ContentPage.Content>
</ContentPage>
</MasterDetailPage.Detail>

在<MasterDetailPage.Master>标签中,我们将定义主视图,在我们的例子中,我们有三个Button按钮用来链接我们的页面。

在<MasterDetailPage.Detail>标记中,如果我们没有在类的构造函数中定义它,我们将包含默认内容。

这些标签对于Master-Detail 页面是必需的。

我们将创建三个页面:Page1,Page2并且Page3具有不同的内容和背景颜色。

现在,在C#部分中,我们将定义默认页面,以便在启动应用程序时显示它。

public MasterPage (){ InitializeComponent ();
Detail = new NavigationPage(new Page1());
//Summary:
//Gets or sets a value that indicates whether or not the visual element
//that is represented by the Xamarin.Forms.MasterDetailPage.Master property
//is presented to the user.
// Remarks:
//Setting this property causes the Xamarin.Forms.MasterDetailPage.IsPresentedChanged
//event to be raised.
//We initialize it to false
IsPresented = false;
}
void goToPage1_Clicked(object sender, System.EventArgs e)
{
//We will display the first page
Detail = new NavigationPage(new Page1());
IsPresented = false;
}
}

属性IsPresented表示点击后应隐藏或不显示主-从菜单。

源代码文件

总结:

至此,我们的Xamarin基础学习笔记就先告一段落,相信通过了如上的学习,大家也能够对Xamarin感兴趣,能够使用和尝试Xamarin。后面大家如果有其他想了解的Xamarin教程也可以PM我们,也欢迎为我们投稿。

Xamarin这个平台总的来讲是一个快速提高开发效率和降低开发成本的一个平台,你可以不必特别了解多个开发平台的语言和环境特性也能开发出多个移动应用,仅凭这一点,Xamarin也已经在移动开发领域拥有了一批拥趸。

而在这其中,葡萄城也是其中的一员,活字格 的用户专属App也是使用Xamarin进行开发的,这个App的主要功能是扩展了活字格应用在移动端的可用性,丰富了用户使用的场景,例如:可以在应用中使用扫码命令帮你快速录入产品信息、使用移动设备定位、手机系统级通知等等功能。

Xamarin 学习笔记 - Page(页面)的更多相关文章

  1. 微信小程序开发:学习笔记[8]——页面跳转及传参

    微信小程序开发:学习笔记[8]——页面跳转及传参 页面跳转 一个小程序拥有多个页面,我们可以通过wx.navigateTo推入一个新的页面.在首页使用2次wx.navigateTo后,页面层级会有三层 ...

  2. Xamarin 学习笔记 - Layout(布局)

    本文翻译自CodeProject文章:https://www.codeproject.com/Articles/1227733/Xamarin-Notes-Xamarin-Forms-Layouts ...

  3. Xamarin 学习笔记 - 配置环境(Windows & iOS)

    本文翻译自CodeProject文章:https://www.codeproject.com/Articles/1223980/Xamarin-Notes-Set-up-the-environment ...

  4. Vaadin学习笔记——Page、UI和View在用法上的区别

    前言 在Vaadin技术框架中会出现三种不同的类,用于架构Web应用.它们分别是:Page.UI.View.本文将对这三者从使用角度进行比较,试图分析三者的异同.本文完全原创,我可不是在强调版权,我只 ...

  5. xamarin 学习笔记01-环境配置

    1.安装AndroidSDK 参考 2.安装NDK NDK下载地址:http://dl.google.com/android/ndk/android-ndk-r10e-windows-x86_64.e ...

  6. AppCan学习笔记----关闭页面listview动态加载数据

    AppCan页面关闭 AppCan 的页面是由两个HTML组成,如果要完全关闭的话需要在主HTML eg.index.html中关闭,关闭方法:appcan.window.close(-1); 管道 ...

  7. Silverlight学习笔记之页面跳转

    在进行项目开发的时候,经常遇到页面之间的跳转,包括silverlight之间以及silverlight和html之间的跳转. silverlight之间的页面跳转包含两点: 1.主窗体和子窗体 用户新 ...

  8. Thinkphp学习笔记6-redirect 页面重定向

    ThinkPHP redirect 方法可以实现页面的重定向(跳转)功能.redirect 方法语法如下: $this->redirect(string url, array params, i ...

  9. xamarin 学习笔记02- IOS Simulator for windows 安装

    微软发布了在window下的ios模拟器 下载 ios模拟器 并安装在windows系统上. Xamarin for Visual Studio 和 网络上的 Mac 中的 Xamarin.iOS 开 ...

随机推荐

  1. Tomcat优化详解

    1          概述         本文档主要介绍了Tomcat的性能调优的原理和方法.可作为公司技术人员为客户Tomcat系统调优的技术指南,也可以提供给客户的技术人员作为他们性能调优的指导 ...

  2. vue中实现动态切换不同的值

    <!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8&quo ...

  3. [Swift]LeetCode637. 二叉树的层平均值 | Average of Levels in Binary Tree

    Given a non-empty binary tree, return the average value of the nodes on each level in the form of an ...

  4. [Swift]LeetCode715. Range 模块 | Range Module

    A Range Module is a module that tracks ranges of numbers. Your task is to design and implement the f ...

  5. vue+cordova构建跨平台应用集成并使用Cordova plugin

    安装 //安装 vue-cil npm install --global vue-cli //安装cordova npm i cordova -g cordova 新建项目 //新建cordova 项 ...

  6. LinkedHashMap 底层分析

    众所周知 HashMap 是一个无序的 Map,因为每次根据 key 的 hashcode 映射到 Entry 数组上,所以遍历出来的顺序并不是写入的顺序. 因此 JDK 推出一个基于 HashMap ...

  7. 【java爬虫】---爬虫+jsoup轻松爬博客

    爬虫+jsoup轻松爬博客 最近的开发任务主要是爬虫爬新闻信息,这里主要用到技术就是jsoup,jsoup 是一款 Java的HTML解析器,可直接解析某个URL地址.HTML文本内容.它提供了一套非 ...

  8. EF实现批量插入

    Z.EntityFramework.BulkInsert EntityFramework 最被人诟病的地方就是它的性能,处理大量数据时的效率.此种条件下,通常会转回使用 ADO.NET 来完成任务.而 ...

  9. 那些令人惊艳的TensorFlow扩展包和社区贡献模型

    随着TensorFlow发布的,还有一个models库(仓库地址:https://github.com/tensorflow/models),里面包含官方及社群所发布的一些基于TensorFlow实现 ...

  10. Android 解压zip文件(支持中文)

    过了n多天后,当再次使用原先博客上写的那篇: Android 压缩解压zip文件 去做zip包的解压的时候,出现了原来没有发现的很多问题.首先是中文汉字问题,使用java的zip包不能很好的解决解压问 ...