上节将Phoneword应用程序扩展到包含第二个屏幕,该屏幕能够跟踪应用程序的拨打历史html
Navigation编程
Xamarin.Form提供了一个内置的导航模型,用于管理一堆页面的导航和用户体验,这个模型实现了Page对象的后进先出(LIFO)堆栈,要从一个页面移动到另外一个页面,应用程序将把一个新页面推到这个堆栈上,要返回到前一个页面,应用程序将从堆栈中弹出当前页面。c#
Xamarin.Forms有一个NavigationPage类,用于管理Page对象的堆栈,NavigationPage类还将在页面顶部添加一个导航栏,该栏将显示标题和与平台相匹配返回到前一个页面回退按钮,下面的代码示例展现了如何用NavigationPage包裹应用程序的第一个页面。async
public App () { ... MainPage = new NavigationPage (new MainPage ()); }
全部ContentPage实例都有一个Navigation属性,该属性公开了修改页面堆栈的方法。只有当应用程序包含NavigationPage时,才能调用这些方法。要导航到CallHistoryPage,须要调用PushAsync方法,以下面的代码示例所示:spa
async void OnCallHistory(object sender, EventArgs e) { await Navigation.PushAsync (new CallHistoryPage ()); }
这将致使新的CallHistoryPage对象被推送到导航堆栈上。要以编程方式返回到原始页面,CallHistoryPage对象必须调用PopAsync方法,以下面的代码示例所示:code
await Navigation.PopAsync();//弹出当前页
Data Bindingorm
数据绑定用于简化Xamarin.Form应用程序显示及与数据交互。它在用户界面和底层应用程序之间创建了链接。BindableObject类包含了不少支持数据绑定的基础设施。数据绑定定义了两个对象之间的关系。源对象将提供数据。目标对象将使用(常常显示)来自源对象的数据。在Phoneword应用程序中,绑定目标是显示电话号码的ListView控件,而PhoneNumbers集合是绑定源。xml
PhoneNumbers集合是在App类中声明和初始化的,htm
public partial class App : Application { public static List<string> PhoneNumbers { get; set; } public App () { PhoneNumbers = new List<string>(); ... } ... }
ListView实例在CallHistoryPage类中声明并初始化,对象
<?xml version="1.0" encoding="UTF-8"?> <ContentPage ... xmlns:local="clr-namespace:Phoneword;assembly=Phoneword" xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml" ...> ... <ContentPage.Content> ... <ListView ItemsSource="{x:Static local:App.PhoneNumbers}" /> ... </ContentPage.Content> </ContentPage>
在本例中,ListView控件将显示ItemsSource属性绑定的IEnumerable数据集合。集合能够是任何类型的对象,但默认状况下,ListView将使用每一个项的ToString方法来显示该项。x:Static静态标记扩展用于指示ItemsSource属性将绑定到App类的静态PhoneNumbers属性,该属性能够在local命名空间中找到