MvvmCross - 如何在iOS TableView中绑定到SelectedItem?

时间:2016-08-12 20:30:35

标签: xamarin xamarin.ios mvvmcross xamarin-binding

我在iOS中有一个TableView,在我的ViewModel中,我在TableView中有一个属性到Selected Item,但我不知道如何为这个属性绑定Selected Item。我怎样才能做到这一点?我的项目是跨平台的。我有一个Android项目和一个iOS项目。在Android项目中,我做了绑定:

<Mvx.MvxListView
                    android:id="@+id/lstViewTasks"
                    android:layout_width="fill_parent"
                    android:layout_height="fill_parent"
                    android:clickable="true"
                    android:focusableInTouchMode="true"
                    android:choiceMode="multipleChoice"
                    local:MvxBind="ItemsSource Tasks; SelectedItem SelectedTask; ItemClick ShowTaskCommand"
                    local:MvxItemTemplate="@layout/projectmytasksitem" />

但我不能在iOS中做同等的绑定。

这是我的TableViewController:

[Register("ProjectMyTasksViewc")]
public class ProjectMyTasksViews : MvxTableViewController<ProjectMyTasksViewModel>
{
        //other things

        var source = new MvxSimpleTableViewSource(TableView, ProjectMyTasksItem.Key, ProjectMyTasksItem.Key);
        TableView.Source = source;

        this.CreateBinding(source).To<ProjectMyTasksViewModel>(viewModel => viewModel.Tasks).Apply();
        this.CreateBinding(source).For(s => s.SelectedItem).To<ProjectMyTasksViewModel>(viewModel => viewModel.SelectedTask).Apply();
        this.CreateBinding(source).For(tableSource => tableSource.SelectionChangedCommand).To<ProjectMyTasksViewModel>(viewModel => viewModel.ShowTaskCommand).Apply();

}

这是我的ViewModel:

public class ProjectMyTasksViewModel : MvxViewModel
{

public Action ShowTaskCommandAction { get; set; }

private IList<Task> _tasks;
public IList<Task> Tasks
{
    get { return _tasks; }
    set { _tasks = value; RaisePropertyChanged(() => Tasks); }
}

private Task _selectedTask;
public Task SelectedTask
{
    get { return _selectedTask; }
    set { _selectedTask = value; RaisePropertyChanged(() => SelectedTask); }
}

private MvxCommand _showTaskCommand;
public MvxCommand ShowTaskCommand
{
    get
    {
        _showTaskCommand = _showTaskCommand ?? (_showTaskCommand = new MvxCommand(ExecuteShowTaskCommand));
        return _showTaskCommand;
    }
}

private void ExecuteShowTaskCommand()
{
    if (!SelectedTask.IsCompleted)
    {
        ShowTaskCommandAction?.Invoke();
    }
}  
}

1 个答案:

答案 0 :(得分:0)

我认为这与ShowTaskCommand执行时间与SelectedTask的时间有关。因此,如果您在ExecuteShowTaskCommand内注释掉代码并在ExecuteShowTaskCommand内放置一个断点以及SelectedTask的集合,您会发现ExecuteShowTaskCommand先运行然后是SelectedTask

的集合

替代实施

为了避免计时问题,您可以将所选任务作为参数传递给您的命令。

MvxCommand<Task> _showTaskCommand;
public MvxCommand<Task> ShowTaskCommand =>
    _showTaskCommand ?? (_showTaskCommand = new MvxCommand<Task>(ExecuteShowTaskCommand));

private void ExecuteShowTaskCommand(Task selectedTask)
{
    if (!selectedTask.IsCompleted)
    {
        ShowTaskCommandAction?.Invoke();
    }
}