首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在windows phone 7中显示Json数据

如何在windows phone 7中显示Json数据
EN

Stack Overflow用户
提问于 2013-09-13 08:18:18
回答 1查看 3.3K关注 0票数 1

我是windows的初学者,我不知道如何从JSON字符串中填充列表框。在我的应用程序中,将有一个来自web服务的Json字符串。

所以,这是我的json字符串json

代码语言:javascript
复制
{
"type":"ok",
"result":
       {
       "Country":[{
                    "title":"Country-1",
                    "description":"US",
                    "status":"1"
                  },
                  {
                    "title":"Country-2",
                    "description":"Australia",
                    "status":"0"
                   },
                   {
                    "title":"Country-3",
                    "description":"Brazil,
                    "status":"0"
                  }      
                 ]
        }
}

我想将其绑定到我的应用程序中的列表框中。我真的不知道,如何绑定在列表框中。

请给我xaml和c#的全部代码。

EN

回答 1

Stack Overflow用户

回答已采纳

发布于 2013-09-13 08:58:37

首先,您需要一个好的库来帮助您将json字符串转换为c#模型表示(DeSerialization)。

您可以编写您的程序,使用内置的平台反序列化程序,也可以只使用NewtonSoft.json。

若要安装NewtonSoft for WP,请使用Nuget。请注意,您必须使用5.0.8版本,因为6.x系列不支持Windows 7。

我把你的json字符串简化了一点,不明白为什么一个国家的财产会包含一个国家的列表?

c#,在后面的代码中

代码语言:javascript
复制
public partial class MainPage : PhoneApplicationPage
{
    // Constructor
    public MainPage()
    {
        InitializeComponent();

        //BindCountries();
    }

    protected override void OnNavigatedTo(NavigationEventArgs e)
    {
        BindCountries();
    }

    private void BindCountries()
    {
        var json =
            "{\"type\":\"ok\",\"countries\":[{\"title\":\"Country-1\",\"description\":\"US\",\"status\":\"1\"},{\"title\":\"Country-2\",\"description\":\"Australia\",\"status\":\"0\"},{\"title\":\"Country-3\",\"description\":\"Brazil\",\"status\":\"0\"}]}";

        var countryResult = JsonConvert.DeserializeObject<CountryResult>(json);

        if (countryResult.Type.Equals("ok", StringComparison.InvariantCultureIgnoreCase))
        {
            lstCountries.ItemsSource = countryResult.Countries;
        }

    }
}

public class CountryResult
{
    public string Type { get; set; }
    public IEnumerable<Country> Countries { get; set; }
}

public class Country
{
    public string Title { get; set; }
    public string Description { get; set; }
    public int Status { get; set; }
}

Xaml:

代码语言:javascript
复制
<phone:PhoneApplicationPage 
x:Class="PhoneApp1.MainPage"
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:phone="clr-namespace:Microsoft.Phone.Controls;assembly=Microsoft.Phone"
xmlns:shell="clr-namespace:Microsoft.Phone.Shell;assembly=Microsoft.Phone"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d" d:DesignWidth="480" d:DesignHeight="768"
FontFamily="{StaticResource PhoneFontFamilyNormal}"
FontSize="{StaticResource PhoneFontSizeNormal}"
Foreground="{StaticResource PhoneForegroundBrush}"
SupportedOrientations="Portrait" Orientation="Portrait"
shell:SystemTray.IsVisible="True">

<!--LayoutRoot is the root grid where all page content is placed-->
<Grid x:Name="LayoutRoot" Background="Transparent">
    <Grid.RowDefinitions>
        <RowDefinition Height="Auto"/>
        <RowDefinition Height="*"/>
    </Grid.RowDefinitions>

    <!--TitlePanel contains the name of the application and page title-->
    <StackPanel x:Name="TitlePanel" Grid.Row="0" Margin="12,17,0,28">
        <TextBlock x:Name="ApplicationTitle" Text="MY APPLICATION" Style="{StaticResource PhoneTextNormalStyle}"/>
        <TextBlock x:Name="PageTitle" Text="page name" Margin="9,-7,0,0" Style="{StaticResource PhoneTextTitle1Style}"/>
    </StackPanel>

    <!--ContentPanel - place additional content here-->
    <Grid  x:Name="ContentPanel" Grid.Row="1" Margin="12,0,12,0">
        <ListBox x:Name="lstCountries">
            <ListBox.ItemTemplate>
                <DataTemplate>
                    <StackPanel>
                        <TextBlock FontSize="{StaticResource PhoneFontSizeExtraLarge}" Text="{Binding Title}" />
                        <TextBlock Text="{Binding Description}" />
                    </StackPanel>

                </DataTemplate>
            </ListBox.ItemTemplate>
        </ListBox>

    </Grid>
</Grid>

结果:

票数 6
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/18781509

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档