Windows 商店应用中的值不在预期范围内

Value does not fall within the expected range in a Windows Store app

我的 xaml 编码如下:

<Page
    x:Name="pageRoot"
    x:Class="wCommander.OrderListing"
    DataContext="{Binding DefaultViewModel, RelativeSource={RelativeSource Self}}"
    xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
    xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
    xmlns:local="using:wCommander"
    xmlns:common="using:wCommander.Common"
    xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
    xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
    mc:Ignorable="d"><Page.Resources>
    <!-- TODO: Delete this line if the key AppName is declared in App.xaml -->
    <x:String x:Key="AppName">Order Lists</x:String>

    <Style x:Key="ContactGroups" TargetType="ListViewItem">
            <Setter Property="HorizontalContentAlignment" Value="Stretch"/>
        </Style>

    </Page.Resources>

<!--
        This grid acts as a root panel for the page that defines two rows:
        * Row 0 contains the back button and page title
        * Row 1 contains the rest of the page layout
    -->
<Grid Background="{ThemeResource ApplicationPageBackgroundThemeBrush}">
    <Grid.ChildrenTransitions>
        <TransitionCollection>
            <EntranceThemeTransition/>
        </TransitionCollection>
    </Grid.ChildrenTransitions>
    <Grid.RowDefinitions>
        <RowDefinition Height="100"/>
        <RowDefinition Height="100"/>
        <RowDefinition Height="*"/>
    </Grid.RowDefinitions>

    <!-- Back button and page title -->
    <Grid Grid.Row="0" Background="#009DC6">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="120"/>
            <ColumnDefinition Width="*"/>
        </Grid.ColumnDefinitions>
        <Button x:Name="backButton" Margin="39,30,39,0" Command="{Binding NavigationHelper.GoBackCommand, ElementName=pageRoot}"
                        Style="{StaticResource NavigationBackButtonNormalStyle}"
                        VerticalAlignment="Top"
                        AutomationProperties.Name="Back"
                        AutomationProperties.AutomationId="BackButton"
                        AutomationProperties.ItemType="Navigation Button"/>
        <TextBlock x:Name="pageTitle" Text="{StaticResource AppName}" Style="{StaticResource HeaderTextBlockStyle}" Grid.Column="1" 
                        IsHitTestVisible="false" TextWrapping="NoWrap" VerticalAlignment="Center" Margin="0,0,30,15" FontSize="36"/>
    </Grid>

    <Grid Grid.Row="1"  Background="#FFFFFF">
        <Grid.ColumnDefinitions>
            <ColumnDefinition Width="1*"/>
            <ColumnDefinition Width="1*"/>
            <ColumnDefinition Width="1*"/>
            <ColumnDefinition Width="1*"/>
            <ColumnDefinition Width="1*"/>
            <ColumnDefinition Width="1*"/>
        </Grid.ColumnDefinitions>
        <TextBlock Text="ORDER ID" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Grid.Column="0" Foreground="#FF58B3D2"/>
        <TextBlock Text="CUSTOMER NAME" HorizontalAlignment="Left" VerticalAlignment="Center" FontSize="20" Grid.Column="1" Foreground="#FF58B3D2"/>
        <TextBlock Text="ORDER DATE" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Grid.Column="2" Foreground="#FF58B3D2"/>
        <TextBlock Text="ORDER TOTAL" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Grid.Column="3" Foreground="#FF58B3D2"/>
        <TextBlock Text="STATUS" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Grid.Column="4" Foreground="#FF58B3D2"/>
        <TextBlock Text="ACTIONS" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Grid.Column="5" Foreground="#FF58B3D2"/>

    </Grid>





        <ListView x:Name="OrderListView"  HorizontalAlignment="Stretch" ItemContainerStyle="{StaticResource ContactGroups}" VerticalAlignment="Stretch" Background="#FFFFFF" Margin="0,0,0,0" Grid.Row="2" SelectionMode="Single" SelectionChanged="index_selected" >

            <ListView.ItemTemplate>
                <DataTemplate>

                    <Grid>
                        <Grid.RowDefinitions>
                            <RowDefinition Height="*"/>
                        </Grid.RowDefinitions>
                        <Grid Grid.Row="0" >
                            <Grid.ColumnDefinitions>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="1*"/>
                                <ColumnDefinition Width="1*"/>
                            </Grid.ColumnDefinitions>

                            <TextBlock Text="{Binding id}" Height="auto" Width="auto" Margin="25,0,25,0" TextWrapping="Wrap" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Foreground="#636D6F" Grid.Column="0"/>
                            <TextBlock Text="{Binding customerName}" Height="auto" Width="auto" Margin="0,0,0,0" TextWrapping="Wrap" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Foreground="#636D6F" Grid.Column="1"/>
                            <TextBlock Text="{Binding shippingCost}" Height="auto" Width="auto" Margin="25,0,25,0" TextWrapping="Wrap" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Foreground="#636D6F" Grid.Column="2"/>
                            <TextBlock Text="{Binding totalSurcharge}" Height="auto" Width="auto" Margin="0,0,0,0" TextWrapping="Wrap" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Foreground="#009DC6" Grid.Column="3"/>
                            <TextBlock Text="{Binding orderStatus}" Height="auto" Width="auto" Margin="25,0,25,0" TextWrapping="Wrap" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Foreground="#636D6F" Grid.Column="4"/>
                            <TextBlock Text="{Binding paymentStatus}" Height="auto" Width="auto" Margin="0,0,25,0" TextWrapping="Wrap" HorizontalAlignment="Center" VerticalAlignment="Center" FontSize="20" Foreground="#636D6F" Grid.Column="5"/>
                        </Grid>
                    </Grid>

                </DataTemplate>
            </ListView.ItemTemplate>
        </ListView>

    </Grid>
</Page>

我正在使用以下代码加载 JSON 网络数据:

public OrderListing()
{
    this.InitializeComponent();
    this.navigationHelper = new NavigationHelper(this);
    this.navigationHelper.LoadState += navigationHelper_LoadState;
    this.navigationHelper.SaveState += navigationHelper_SaveState;
    loadData1();
}

private async void loadData1()
{
    HttpClient http = new HttpClient();

    var response = await http.GetStringAsync("http://10.0.40.117/" + "rest/admin/order/list.json");

    var orderData = JsonConvert.DeserializeObject<OrderRootClass>(response);

    OrderListView.ItemsSource = orderData;
}

这是订单根 class:

public class OrderRootClass
{
    public Order[] orders { get; set; }

}

报错。我发现了一些关于此的 post 但这没有帮助。

应为 ItemsSource 属性 分配订单集合,而不是 OrderRootClass 实例。

var orderData = JsonConvert.DeserializeObject<OrderRootClass>(response);

OrderListView.ItemsSource = orderData.orders; // here

但是,它应该给你一个编译器错误,指出 orderData 没有实现 IEnumerable。