Xlabs 扩展选取器 选定项 属性不绑定



我在项目中使用此控件,无法获取属性绑定。

我的 xaml 代码:

   <controls:ExtendedPicker x:Name="myPicker" ItemsSource="{Binding ListaLugaresTrabajo}" DisplayProperty="NombreLugar" SelectedItem="{Binding SelectedLugarTrabajo}" />

我的视图模型代码:

private ObservableCollection<LugarDeTrabajo> _listaLugaresTrabajo;
    public ObservableCollection<LugarDeTrabajo> ListaLugaresTrabajo {
        get {
            return _listaLugaresTrabajo;
        }
        set {
            _listaLugaresTrabajo = value;
            RaisePropertyChanged (() => ListaLugaresTrabajo);
        }
    }
    private LugarDeTrabajo _selectedLugarTrabajo;
    public LugarDeTrabajo SelectedLugarTrabajo {
        get {
            return _selectedLugarTrabajo;
        }
        set {
            _selectedLugarTrabajo = value;
            RaisePropertyChanged (() => SelectedLugarTrabajo);
        }
    }

我的模型代码(也使用 sqlite):

[Table ("LugaresDeTrabajo")]
public class LugarDeTrabajo
{
    [PrimaryKey, AutoIncrement]
    public int Id { get; set; }
    [Unique]
    public string NombreLugar { get; set; }
}

ItemsSource 和 DisplayProperty 工作正常,但 SelectedItem 始终为空。

我使用MvvmCross框架,在应用程序的其余部分可以正常工作。

这是一个共享项目,我正在尝试Android版本。

这可能发生吗?

溶液:将"选定项属性"设置为"双向绑定模式"。

正确的 Xaml 代码:

<controls:ExtendedPicker x:Name="myPicker" ItemsSource="{Binding ListaLugaresTrabajo}" DisplayProperty="NombreLugar" SelectedItem="{Binding SelectedLugarTrabajo, Mode=TwoWay}" />

根据 ExtendedPicker 源代码SelectedItem可绑定属性的默认绑定模式设置为 OneWay 。这意味着 ViewModel 中的更改会反映在视图中,但不会反映在相反的方向上。

如果需要将更改从 ViewModel 传播到 View,反之亦然,请按以下方式设置SelectedItem属性:

SelectedItem="{Binding SelectedLugarTrabajo, Mode=TwoWay}" 

如果只想将更改从视图传播到视图模型,请按以下方式设置SelectedItem

SelectedItem="{Binding SelectedLugarTrabajo, Mode=OneWayToSource}" 
您也可以

依赖SelectedIndexChanged属性。下面是一个示例:

<controls:ExtendedPicker x:Name="myPicker" ItemsSource="{Binding ListaLugaresTrabajo}" DisplayProperty="NombreLugar"  SelectedIndexChanged="OnLugarChange"/>
    async void OnLugarChange(object sender, System.EventArgs e)
    {
        if (myPicker.SelectedIndex != -1)
        {
            _selectedLugarTrabajo = myPicker.SelectedItem as LugarDeTrabajo;
        }
     }

最新更新