我正在使用Xaml为UI处理Xamarin表单项目的数据绑定。到目前为止它非常简单:
XAML:
<?xml version="1.0" encoding="utf-8" ?>
xmlns:viewModels="clr-namespace:Watson.ViewModels;assembly=Watson"
x:Class="Watson.Views.DeviceCheck">
<ContentPage.BindingContext>
<viewModels:DeviceCheckViewModel/>
</ContentPage.BindingContext>
<!--<ActivityIndicator Color="Red" IsRunning="True"
x:Name="loadingScreen"/>-->
<StackLayout>
<Label Text="Checking Device.."/>
<Button Text="page nav"
Command="{Binding NextButton}"></Button>
</StackLayout>
背后的代码:
namespace Watson.Views
{
[XamlCompilation(XamlCompilationOptions.Compile)]
public partial class DeviceCheck:ContentPage
{
private DeviceCheckViewModel viewModel;
public DeviceCheck() {
InitializeComponent();
BindingContext = viewModel = new DeviceCheckViewModel(this.Navigation);
}// end of constructor
}// end of class
}// end of namespace
这是尝试绑定到视图模型并使用绑定命令在按钮单击时转到另一个页面。我得到的错误是“给定的密钥不在字典中”,这是在尝试构建时。我把问题排成一行:<viewModels:DeviceCheckViewModel/>
我不知道为什么会出现这种错误。
这是视图模型:
namespace Watson.ViewModels
{
public class DeviceCheckViewModel: INotifyPropertyChanged
{
public INavigation Navigation { get; set; }
public ICommand NextButton { protected set; get; }
public DeviceCheckViewModel(INavigation navigation)
{
this.Navigation = navigation;
this.NextButton = new Command(async () => await GotoNextPage());
}
public async Task GotoNextPage()
{
await Navigation.PushAsync(new RegisterDevice());
}
public event PropertyChangedEventHandler PropertyChanged;
protected void OnPropertyChanged(string propertyName)
{
if (PropertyChanged != null)
PropertyChanged(this,
new PropertyChangedEventArgs(propertyName));
}
}
}
我追求这条路线的原因是坚持MVVM架构。因此,将页面导航放在后面的代码中并不是一个真正的选择。同样只是一个注释,所有模型,视图模型和视图都在具有相同名称的文件夹结构中。
任何帮助,将不胜感激。
您在代码中设置绑定上下文:
BindingContext = viewModel = new DeviceCheckViewModel(this.Navigation);
因此,也没有必要采用xaml方式。这也创建了DeviceCheckViewModel
的一个实例并将其设置为绑定上下文:
<ContentPage.BindingContext>
<viewModels:DeviceCheckViewModel/>
</ContentPage.BindingContext>
但是,因此它需要一个无参数的构造函数。这可能是你获得超越的原因。
我知道这是一个较旧的线程但是当遇到同样的问题时,我不满意给定的答案对我来说真的可以接受。我也更喜欢在标记中保留这种类型的绑定;将代码保持在最低限度。
对我有用的是删除类后面代码的XamlCompilation(...)属性。尝试从DeviceCheck类中删除此属性。
我也注意到类后面的大多数代码都有这个属性,但它只给出了一些问题。