c# - 如何从 JArray 获取子对象到 ObservableCollection

标签 c# json windows-phone-8 json.net

我正在为 Windows Phone 开发一个应用程序,其中的 ListBox 显示来自 JSON 文件的数据。我使用的是 JArray,我可以根据数组位置显示数据。但是,如果我想显示我的 JSON 文件中的所有数据(该文件没有静态数据,以后可能会修改数据)怎么办?

我的 JSON:

[
    {
        "xId": "52",
        "result": {
            "type": "Basico.Bean.MunicipioClass.TMunicipio",
            "id": 1,
            "fields": {
                "FRefCount": 0,
                "FId": 52,
                "FNome": "Sumare",
                "FEstado": "SP",
                "FPais": "Brasil"
            }
        }
    },
    {
        "xId": "52",
        "result": {
            "type": "Basico.Bean.MunicipioClass.TMunicipio",
            "id": 1,
            "fields": {
                "FRefCount": 0,
                "FId": 52,
                "FNome": "Indaiatuba",
                "FEstado": "SP",
                "FPais": "Brasil"
            }
        }
    }
]

我的代码:

InitializeComponent();

String text;


using (var store = IsolatedStorageFile.GetUserStoreForApplication())
using (var readStream = new IsolatedStorageFileStream("json.html", FileMode.Open, FileAccess.Read, FileShare.Read, store))
using (var reader = new StreamReader(readStream))
{
    text = reader.ReadToEnd();
}
{
    try
    {


        DataContext = this;

        // Your JSON string
        string json = text;

        // Parse as JObject
        JArray jObj = JArray.Parse(json);


        // Extract what you need, the "fields" property
        JToken jToken = jObj[0]["result"]["fields"];

        // Convert as Fields class instance
        Fields fields = jToken.ToObject<Fields>();

        Items = new ObservableCollection<Fields>() { fields };
    }

    catch (Exception ex)
    {
        MessageBox.Show(ex.Message);
    }
}

public ObservableCollection<Fields> Items { get; set; }

public class Fields
{
    [JsonProperty(PropertyName = "FId")]
    public int FId { get; set; }

    public string FNome { get; set; }
    public string FEstado { get; set; }
    public string FPais { get; set; }
}

当我使用“[0]”时,返回的是 Sumare SP:

JToken jToken = jObj[0]["result"]["fields"];

当我使用“[1]”时,返回的是 Indaiatuba SP:

JToken jToken = jObj[1]["result"]["fields"];

我需要这样的:

Sumare SP 因达亚图巴 SP

最佳答案

如果我正确理解你的问题,你正试图从 JSON 中获取所有“字段”对象到你的 ObservableCollection<Fields> 中。 .以下是您可以如何做到这一点:

JArray jObj = JArray.Parse(json);

Items = new ObservableCollection<Fields>(
        jObj.Children().Select(jo => jo["result"]["fields"].ToObject<Fields>()));

关于c# - 如何从 JArray 获取子对象到 ObservableCollection,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/25266694/

相关文章:

c# - 文件选取器的 Windows 8 手机应用代码错误

c# - WP8 项目 : The "CompileXaml" task failed unexpectedly

c# - 如何在另一台计算机上使用C++/CLI程序集运行项目?

c# - 无意代码第一异常 |使用数据库优先的 Effort.Ef6 Entity Framework 单元测试

javascript - 如何访问数组中的元素?

json - 如何让 JSONDecoder 解析这种格式? (yyyy-MM-dd'T'HH :mm:ss. SSSSSSS)

c# - 尝试更改 AppBar 项的 IsEnabled 属性时出现 NullReferenceException 错误

c# - Entity Framework CreateObjectset Attach方法未更新

c# - 如何按对象列表分组并将此列表声明为 View 模型的属性

java - 如何使用i18n? (嬉皮士)