1

現在、ViewModel のデザイン データを利用して、ビューのデータをモックアップしようとしています。具体的には、Silverlight アプリケーション用の View フロント エンドと ViewModel バックエンドがあります。

他のビューをモックアップしたとき、物事は完全に機能しました。この特定のビューでも、唯一の問題はコレクションにあるようです。

「CategoryName」に値を割り当てようとすると、「CategoryItem」でエラーが発生し続けるのはなぜですか? 何が問題を引き起こしているのかわかりません...

以下のコード:

私の設計データ:

<vm:MainPageViewModel
    xmlns:vm="clr-namespace:WebCatalog.ViewModels"    
    xmlns:m="clr-namespace:WebCatalog.Models"   
    SelectedTab="Category 1"
    ProjectName="New Project Name"
    ShowPopup="False"
    IsBusy="False"
    CurrentUser="Alex"
    >
    <vm:MainPageViewModel.Categories>
        <m:CategoryItem CategoryName="test"/>
    </vm:MainPageViewModel.Categories>


</vm:MainPageViewModel>

私の単純化されたViewModel:

public class MainPageViewModel {
    public string SelectedTab {get;set;}
    public string ProjectName {get;set;}
    public bool ShowPopup {get;set;}
    public bool IsBusy {get;set;}
    public string CurrentUser {get;set;}

    public ObservableCollection<CategoryItem> Categories {get;private set;}

    public MainPageViewModel()
    {
         Categories = new ObservableCollection<CategoryItem>();
    }
}

最後に、私の(簡略化された)ビュー:

<UserControl 
     xmlns:d="http://schemas.microsoft.com/expression/blend/2008" 
      d:DataContext="{d:DesignData Source=../SampleData/MainWindowSampleData.xaml}">
<!-- Decision Categories -->
                <StackPanel Width="200" toolkit:DockPanel.Dock="Left" Height="100">
                    <TextBlock Text="{Binding CurrentUser}">meep</TextBlock>
                    <ItemsControl Height="100" ItemsSource="{Binding Categories}">
                        <ItemsControl.ItemTemplate>
                            <DataTemplate>
                                <StackPanel>
                                    <TextBlock>Itemalkdjfa;ldfj;lakdsjfladfjal;dfjaldfja</TextBlock>
                                    <TextBlock Text="{Binding CategoryName}"></TextBlock>
                                </StackPanel>
                            </DataTemplate>
                        </ItemsControl.ItemTemplate>
                    </ItemsControl>

                </StackPanel>
4

1 に答える 1

0

VM の変更時

public ObservableCollection<CategoryItem> Categories {get;private set;}

public ObservableCollection<CategoryItem> Categories {get;set;}

それ以外の場合、私のサンプル xaml バインディングは、次のようにデザイン モードで表示および動作しました。

<local:MainVM x:Key="myMainVM">
    <local:MainVM.Categories>
        <local:CategoryItem Name="Test" />
    </local:MainVM.Categories>
</local:MainVM>

...

<ListBox DataContext="{StaticResource myMainVM}" 
         ItemsSource="{Binding Categories}">
    <ItemsControl.ItemTemplate>
        <DataTemplate><TextBlock Text="{Binding Name}"/></DataTemplate>
    </ItemsControl.ItemTemplate>
</ListBox>

VM があなたのものをミラーリングし (プライベート セットを除く)、VM が Silverlight 上の Xaml に読み込まれ、デザイン モードでデータが表示された場所。

public class MainVM
{

    public ObservableCollection<CategoryItem> Categories { get; set; }

    public MainVM()
    {
        Categories = new ObservableCollection<CategoryItem>();
    }

}

public class CategoryItem
{
    public string Name { get; set; }
}
于 2015-08-04T18:03:48.007 に答える