如何使用MvvmCross流畅的API将RecyclerView项目的TextView绑定到Android上ViewModel的属性?

前端之家收集整理的这篇文章主要介绍了如何使用MvvmCross流畅的API将RecyclerView项目的TextView绑定到Android上ViewModel的属性?前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。
我在我的Xamarin Android项目中使用MvvmCross.我有一个MvxActivity与MvxRecyclerView,我已在其布局文件中分配了一个项目模板.
<MvxRecyclerView
    android:id="@+id/my_recycler_view"
    local:MvxItemTemplate="@layout/item_recycler_view" />

@R_502_93@l非常简单,它只包含一个属性,用于保存要在RecyclerView中显示的数据:

public class Main@R_502_93@l : Mvx@R_502_93@l
{
    private IEnumerable<@R_502_93@lItem> _@R_502_93@lItems;
    public IEnumerable<@R_502_93@lItem> @R_502_93@lItems
    {
        get { return _@R_502_93@lItems; }
        set { SetProperty(ref _@R_502_93@lItems,value); }
    }    
}

通常,我喜欢尽可能多地使用MvvmCross流畅的API,因为隐式重构支持.
所以在我的活动中,我绑定了MvxRecyclerView的属性,如下所示:

var recyclerView = View.FindViewById<MvxRecyclerView>(Resource.Id.my_recycler_view);
var set = this.CreateBindingSet<MainView,Main@R_502_93@l>();
set.Bind(recyclerView)
    .For(v => v.ItemsSource)
    .To(vm => vm.@R_502_93@lItems);
set.Apply();

到现在为止还挺好.现在,项模板的布局文件基本上只包含一个TextView:

<LinearLayout>
    <TextView
        android:id="@+id/innerText" />
</LinearLayout>

我的@R_502_93@lItem类看起来像这样:

public class @R_502_93@lItem
{
    public string Title { get; set; }
}

我现在的问题是,如何以及在何处使用流畅的API将TextView.Text属性绑定到@R_502_93@lItem.Title属性

我知道通过在项目模板布局文件中提供MvxBind属性,没有流畅的API很容易,但我真的更喜欢流畅的API解决方案.

@H_502_26@解决方法
继承自MvxRecyclerAdapter并为RecyclerView创建自定义适配器.覆盖OnCreateViewHolder并返回自定义ViewHolder.
public class MyAdapter : MvxRecyclerAdapter
{
    public MyAdapter(IMvxAndroidBindingContext bindingContext)
        : base(bindingContext)
    {
    }

    public override RecyclerView.ViewHolder OnCreateViewHolder(ViewGroup parent,int viewType)
    {
        var itemBindingContext = new MvxAndroidBindingContext(parent.Context,this.BindingContext.LayoutInflaterHolder);
        var view = this.InflateViewForHolder(parent,viewType,itemBindingContext);

        return new MyViewHolder(view,itemBindingContext);
    }
}

在此ViewHolder中,您可以使用Fluent API进行绑定.

public class MyViewHolder : MvxRecyclerViewHolder
{
    private readonly TextView textView;

    public MyViewHolder(View itemView,IMvxAndroidBindingContext context)
        : base(itemView,context)
    {
        this.textView = itemView.FindViewById<TextView>(Android.Resource.Id.Text1);

        this.DelayBind(() =>
        {
            var set = this.CreateBindingSet<MyViewHolder,@R_502_93@lItem>();
            set.Bind(this.textView).To(x => x.Title);
            set.Apply();
        });
    }
}

在您的Activity中创建适配器并将其添加到RecyclerView:

var adapter = new MyAdapter((IMvxAndroidBindingContext)this.BindingContext);
recyclerView.Adapter = adapter;

并将您的项目绑定到您的适配器的ItemsSource:

set.Bind(this.adapter).For(x => x.ItemsSource).To(x => x.@R_502_93@lItems);

猜你在找的Android相关文章