Xamarin.Froms 第20局:导航
2019-02-19 本文已影响3人
dotNET之家
总目录
前言
本文介绍导航:
一、导航概述
二、传递数据
三、导航堆栈
四、导航栏
环境
1.Visual Studio 2017
2.Xamarin.Froms 4.0.0.62955-pre2
3.Android 4.4(API 19)或更高版本
4.约定:XF代表Xamarin.Forms
内容
一、导航概述
主要介绍页面之间的导航,即:NavigationPage。使用NavigationPage可以向前或向后导航页面。
从一页跳转到另一页,新的页面会置于顶层,原理如下图所示:
data:image/s3,"s3://crabby-images/74a6d/74a6d6db95b0376727ba37db94ec268948193072" alt=""
从一页返回到上一页,最顶层页面会先释放,原理如下图所示:
data:image/s3,"s3://crabby-images/6081d/6081d042d2db04ca80e6cefdc37870c1cf212000" alt=""
实现效果
data:image/s3,"s3://crabby-images/9b32a/9b32a4a99e58bdbd00b221b71218dab3449b3358" alt=""
data:image/s3,"s3://crabby-images/e30d9/e30d94a6989249b88638d0ad2ea752f4a7fd2689" alt=""
实现方式
data:image/s3,"s3://crabby-images/a469e/a469eb960015c5bf926ee681770dca7b387809d1" alt=""
创建根页,即:用MainPage的实例作为参数实例化NavigationPage,并将NavigationPage的实例设为主页。这样才可以在页面中使用Navigation属性的导航方法。
data:image/s3,"s3://crabby-images/edc7c/edc7c038de9ddad9324414e872e8f3888c7e1942" alt=""
data:image/s3,"s3://crabby-images/5bccb/5bccb278358fd6c79008ef6a37be7b91a25a1add" alt=""
data:image/s3,"s3://crabby-images/89120/89120c0e338cf532299b3eab3f526e5592eeec6d" alt=""
data:image/s3,"s3://crabby-images/466cc/466cc993221d4b9f1e6f19a0e9c22f202de9f3ad" alt=""
1.Navigation属性:导航主要使用Navigation的方法,其定义如下图所示:
data:image/s3,"s3://crabby-images/a1d8f/a1d8f5a55c302284a1d0bd9466e4df79c0e2bd02" alt=""
2.跳转到指定页:
- PushAsync(Page page):跳转到指定页(page);
- PushAsync(Page page,bool animated):跳转到指定页(page),animated是否带有动画效果,默认为true;
3.返回到上一页:
- PopAsync():返回上一页;
- PopAsync(bool animated):返回上一页,animated是否带有动画效果,默认为true;
- PopToRootAsync():返回到根页;
- PopToRootAsync(bool animated):返回到根页,animated是否带有动画效果,默认为true;
4.插入指定页
- InsertPageBefore(Page page,Page before):在before页面之前插入page页;
5.移除指定页
- RemovePage(Page page):移除指定页面;
6.导航堆栈:NavigationStack。
二、传递数据
页面之间传递数据有两种方法:
- 通过页面构造函数传递数据
- 通过BindingContext传递数据
实现效果
data:image/s3,"s3://crabby-images/ca149/ca149574589e9d7a93293f5bb9f037a9623fd197" alt=""
data:image/s3,"s3://crabby-images/5b8d8/5b8d8a7b0f5f102ad2efccb9479963e6b086431e" alt=""
实现方式
data:image/s3,"s3://crabby-images/28f93/28f9342a1b47b1e8cc92ba674119537c0d33864c" alt=""
data:image/s3,"s3://crabby-images/8feed/8feedc10214bf6e355c5cc5d5883a7dbc3a2b9a0" alt=""
data:image/s3,"s3://crabby-images/d9452/d94528c0b926a32d8269048db6c8e21de66139fb" alt=""
data:image/s3,"s3://crabby-images/d8b17/d8b17886758763c40d3c68df1606d7f01113c2a7" alt=""
三、导航堆栈
导航堆栈:通过Navigation的NavigationStack属性可以获取导航堆栈中的页面。
NavigationStack是IReadOnlyList<Page>类型,即:它是一个页面的集合,但是只读。可以通过Navigation的方法进行增删。
四、导航栏
导航栏:XF中所有的View都可以在Navigation的导航栏中显示。
实现效果
data:image/s3,"s3://crabby-images/b3689/b36898c6f017a4be8435333cb826a6c77270e5b1" alt=""
data:image/s3,"s3://crabby-images/7184b/7184bc4560492093356e0eb4d12e1ee73e06315e" alt=""
实现方式
data:image/s3,"s3://crabby-images/3f2b3/3f2b3f535817d3f3606a4dcc62d38064787722ff" alt=""
可以在Navigation.TitleView中自定义导航栏。
data:image/s3,"s3://crabby-images/e208e/e208e92acca0d5c5a4b441e3b3da09f7f16ff143" alt=""
1.NavigationPage.HasBackButton:是否显示返回按钮。
2.NavigationPage.HasNavigationBar:是否显示导航栏。
后语
下篇介绍消息中心,待续...