使用mvvm在xamarin表单中的视图之间传递数据

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了使用mvvm在xamarin表单中的视图之间传递数据相关的知识,希望对你有一定的参考价值。

我正在尝试在页面之间导航并同时绑定数据。

这是我尝试过的:

public ICommand GetIdeasCommand
{
    get
    {
        return new Command(async () =>
        {
            Ideas = await _apiServices.GetIdeasAsync();
            await Application.Current.MainPage.Navigation.PushAsync(new IdeasSinglePage(Ideas));
        });
    }
}

假设Ideas是我从json获得的数组列表。但这种方法对我没有帮助,因为我得到一个空白页面。此外,如果我在页面内调用此功能一切都很好。这篇文章给了我一个想法:How to pass a parameter from one Page to another Page in Xamarin.Forms?

我的看法 :

<ContentPage xmlns="http://xamarin.com/schemas/2014/forms"
         xmlns:x="http://schemas.microsoft.com/winfx/2009/xaml"
         x:Class="Ideas.Pages.IdeasSinglePage"
         xmlns:vm="clr-namespace:Ideas.ViewModel;assembly=Ideas"
          Title="My Page">

<ContentPage.BindingContext>
    <vm:IdeasViewModel/>
</ContentPage.BindingContext>

        <ListView.ItemTemplate>
            <DataTemplate>
                <ViewCell>
                    <StackLayout Padding="20, 10">
                        <Label Text="{Binding Ideas}"
                               FontSize="12"
                               TextColor="RoyalBlue"/>
                    </StackLayout>
                </ViewCell>
            </DataTemplate>
        </ListView.ItemTemplate>
    </ListView>

代码背后:

public partial class IdeasSinglePage : ContentPage
{
    public IdeasSinglePage(List<Models.Ideas> ideas)
    {

      InitializeComponent();
      this.BindingContext = new IdeasSinglePage(ideas); //the app breaks here
    }
}

谢谢。

答案

您对BindingContext的理解不足。通常将ViewModel绑定到BindingContext。你在这做什么

this.BindingContext = new IdeasSinglePage(ideas); //the app breaks here

没有意义。

您要作为上下文传递要加载的页面?只需完全删除此行。因为在你最近的评论中你说你不想开始使用ViewModel,你将在CodeBehind中做的是:

public partial class IdeasSinglePage : ContentPage
{
  public IdeasSinglePage(List<Models.Ideas> ideas)
  {
    InitializeComponent();
    listViewName.ItemsSource = ideas;
  }
}

在你的xml中你给listView一个名字。您需要此名称来引用后面的代码列表。

希望能帮助到你

另一答案

您的问题很明显,您将数据传递给ContentPage,但您没有对它执行任何操作。一般来说,将参数从一个ViewModel传递到另一个ViewModel是一个非常简单的问题。

这是没有XAML的插图:

public class MyFirstPage : ContentPage
{
  public MyFirstPage()
  {
    this.BindingContext = new MyFirstPageViewModel();
  }
}

public class MyFirstPageViewModel : INotifyPorpertyChanged
{
  public ICommand<List<string>> DownloadDataCmd { get; }

  public MyFirstPageViewModel()
  {
    DownloadDataCmd = new Command<List<string>>(async () => {
        var data = await dataService.DownloadData();
        await navService.PushAsync(new MySecondPage(data));
    });
  }
}

public class MySecondPage : ContentPage
{
  public MySecondPage(List<string> downloadedData)
  {
    this.BindingContext = new MySecondPageViewModel(downloadedData);
  }
}

public class MySecondPageViewModel : INotifyPropertyChanged
{
  public List<string> Data { get; }
  public MySecondPageViewModel(List<string> downloadedData)
  {
     // Do whatever is needed with the data
     Data = downloadedData;
  }
}

现在,看看这个解决方案,几乎没有问题: 1.为什么不直接在第二页下载数据? 2.如果您需要在整个应用程序中使用数据,为什么不将数据存储在缓存或数据库中?

以上是关于使用mvvm在xamarin表单中的视图之间传递数据的主要内容,如果未能解决你的问题,请参考以下文章

如何在 Xamarin 表单中的视图模型之间最好地传递信息 - Prism [关闭]

如何在 Xamarin 表单中使用 MVVM 仅为集合视图中的选定框架设置颜色?

如何将相同的viewmodel设置为xamarin表单中的新mvvm中的两个视图

Xamarin MVVM 将数据传递到其他视图

在 xamarin.ios 中的视图控制器之间传递数据

如何将条目参数传递给 Xamarin MVVM 视图模型