如何在Xamarin表单中使用不可点击的标题创建列表视图

时间:2018-10-30 08:07:40

标签: xamarin.forms

我需要使用xamarin形式的列表视图来创建带有说明的标头。

我需要在列表视图中为标题和详细信息使用单独的样式。

我正在尝试以下代码,

<ListView RowHeight="74" ItemsSource="{Binding UserEmailList}" IsGroupingEnabled="true">
    <ListView.GroupHeaderTemplate>
      <DataTemplate>
        <ViewCell>
          <StackLayout Orientation="Vertical">
          <BoxView Style="{StaticResource separator}"></BoxView>
          <Label Text="{Binding Heading}" Style="{StaticResource labelHeaderTitle}"/>
          <BoxView Style="{StaticResource separator}"></BoxView>
          </StackLayout>
        </ViewCell>
      </DataTemplate>
    </ListView.GroupHeaderTemplate>
    <ListView.ItemTemplate>
      <DataTemplate>
        <ViewCell>
            <StackLayout Orientation="Horizontal">
              <Label Text="{Binding EmailAddress}" Style="{StaticResource labelListItem}">
              </Label>
              <Image HeightRequest="16" HorizontalOptions="End" VerticalOptions="Center" Source="arrow.png" Margin="0,0,15,0"></Image>
            </StackLayout>
        </ViewCell>
      </DataTemplate>
    </ListView.ItemTemplate>
  </ListView>

但是,当我使用代码时,列表视图始终显示为空。

请让我知道如何使用xamarin表单中的XAML创建此文件。

enter image description here

public class EmailItemViewModel
{
    public string Heading { get; set; }
    public bool HasEmailAddress { get; set; }
    public string EmailAddress { get; set; }
}

public class ProfileEmailAddressViewModel : ProfileDetailsViewModel
{
    public ProfileEmailAddressViewModel()
    {
        Title = "Email addresses";
        LoadUserEmailList();
    }

    private List<EmailItemViewModel> userEmailList;

    public List<EmailItemViewModel> UserEmailList {
        get { return userEmailList; }
        set
        {
            if(value != null)
            {
                userEmailList = value;
            }
        }
    }

    private void LoadUserEmailList()
    {
        UserEmailList = new List<EmailItemViewModel>();
        foreach (var package in Employee.Packages)
        {
            EmailItemViewModel emailItemViewModel = new EmailItemViewModel();
            emailItemViewModel.Heading = package.Employer.Name.ToUpper();
            emailItemViewModel.EmailAddress = package.WorkEmailAddress;
            emailItemViewModel.HasEmailAddress = HasEmailAddress(package.WorkEmailAddress);

            UserEmailList.Add(emailItemViewModel);
        }

        EmailItemViewModel personalEmail = new EmailItemViewModel();
        personalEmail.Heading = "PERSONAL EMAIL";
        personalEmail.EmailAddress = Employee.HomeEmailAddress;
        personalEmail.HasEmailAddress = HasEmailAddress(Employee.HomeEmailAddress);

        UserEmailList.Add(personalEmail);
    }
}

1 个答案:

答案 0 :(得分:0)

        Try Listview.Header 
        like this 

    <ListView RowHeight="74" ItemsSource="{Binding UserEmailList}" IsGroupingEnabled="true">
        <ListView.Header>     
              <BoxView Style="{StaticResource separator}"></BoxView>
              <Label Text="{Binding Heading}" Style="{StaticResource labelHeaderTitle}"/>
              <BoxView Style="{StaticResource separator}"></BoxView>

        </ListView.Header>
        <ListView.ItemTemplate>
          <DataTemplate>
            <ViewCell>
<ViewCell.View>
                <StackLayout Orientation="Horizontal">
                  <Label Text="{Binding EmailAddress}" Style="{StaticResource labelListItem}">
                  </Label>
                  <Image HeightRequest="16" HorizontalOptions="End" VerticalOptions="Center" Source="arrow.png" Margin="0,0,15,0"></Image>
                </StackLayout>
</ViewCell.View>
            </ViewCell>
          </DataTemplate>
        </ListView.ItemTemplate>
      </ListView>