Xamarin.Forms - 是否有一种机制来"包括"部分观点?

时间:2016-03-24 15:08:46

标签: xamarin user-controls templating xamarin-forms

Xamarin.Forms是否有包含概念?

我正在创建一个跨所有页面都有共享标头的应用。有没有办法创建一次标题并将其包含在所有页面上?更好的是,有没有办法创建模板或可重复使用的布局,您可以将所有内容放在每个页面内?这与.NET MVC的_Layout文件类似。

2 个答案:

答案 0 :(得分:10)

您需要的是2.1.0中引入的ControlTemplate。

在Application.Resources中的ResourceDictionary中创建一个控件模板。

<?xml version="1.0" encoding="utf-8" ?>
<Application
    xmlns="http://xamarin.com/schemas/2014/forms"
    xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
    x:Class="Mobile.App">
  <Application.Resources>
    <ResourceDictionary>
      <ControlTemplate x:Key="MainPageTemplate">
        <StackLayout>
          <Label Text="Header Content" FontSize="24" />         
          <ContentPresenter />
        </StackLayout>
      </ControlTemplate>
    </ResourceDictionary>
  </Application.Resources>
</Application>

然后在您的ContentPage中分配ControlTemplate

<?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="Mobile.MainPage"
               ControlTemplate="{StaticResource MainPageTemplate}">

  <Label Text="Main Page Content" FontSize="18" />

</ContentPage>

然后你最终得到了

enter image description here

参考:http://www.xamarinhelp.com/xamarin-forms-page-templates/

答案 1 :(得分:6)

是。您可以使用用户控件。您可以仅使用XAML或代码。我将解释XAML方式。

只需添加新的XAML页面,然后将根类型从ContentPage更改为StackLayout。根类型可以是每个其他布局或控件。你必须决定什么是最合适的。

<强> MyControl.xaml

<?xml version="1.0" encoding="utf-8" ?>
<StackLayout xmlns="http://xamarin.com/schemas/2014/forms"
             xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
             x:Class="App6.MyControl">
    <Label Text="{Binding Name}" />
    <Label Text="{Binding Age}" />
    <Label Text="{Binding CatAmount}" />
</StackLayout>

我们将属性Name, Age, CatAmount绑定到三个不同的标签。我们假设此控件的BindingContextPersonData类型的对象(见下文)。 在您的代码中,您还必须更改类型。

<强> MyControl.xaml.cs

public partial class MyControl : StackLayout
{
    public MyControl()
    {
        InitializeComponent();
    }
}

在您的页面中,您必须添加一个新的命名空间(例如local指向您的程序集,例如App6MyApp.Whatever)。然后,您可以通过local:MyControl使用它。在我们的示例控件中,我们将BindingContext绑定到Person,它是我们的Page的BindingContext的属性,即(在我们的例子中)页面本身。如果您的控件位于子命名空间中,则必须相应地更改命名空间部分。

Page2.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"
             xmlns:local="clr-namespace:App6;assembly=App6"
             x:Class="App6.Page2">
    <local:MyControl BindingContext="{Binding Person}"></local:MyControl>
</ContentPage>

<强> Page2.xaml.cs

public class PersonData
{
    public string Name { get; set; }
    public int Age { get; set; }
    public int CatAmount { get; set; }
}

public partial class Page2 : ContentPage
{
    public PersonData Person { get; set; }

    public Page2()
    {
        Person = new PersonData {Age = 28, Name = "Sven", CatAmount = 2};
        InitializeComponent();
        BindingContext = this;
    }
}

在您提到的场景中,您可以简单地从ContentPage继承并添加您的公共元素,并使用继承的Page作为页面的基类。

TemplatedPage - Xamarin.Forms 2.1

使用Xamarin.Forms 2.1,他们引入了TemplatedPage。您可以在此处找到示例:http://xfcomplete.net/general/2016/01/20/control-templates/。带LoginView的{​​{1}}示例完全适合您的方案。