如何对 C# Jobject 进行排序

How to sort C# Jobject

在我的模型中,我有 public JObject GenericData { get; set; } 这个 属性 我需要在我的控制器中创建 Jobject 来将数据传递给这个 属性。我已经这样做了,但现在我需要在 Jobject 中对数据进行排序,但我不知道该怎么做。开箱即用的 Jobject 没有排序功能。 我在控制器中的代码如下所示。

var attributes = _context.AttributeRecords.Include(a => a.Attribute);
    var queryRecords = attributes.Select(l => new
        {
            RecordId = l.RecordId,
            ProjectId = l.ProjectId,
            Attribute = l.Attribute.Description,
            Value = l.Value,
            InfoId = l.InfoId
        }).ToList();
        var recordsValues = queryRecords.Where(b => b.InfoId == i.InfoId).ToList();
        var jObjectValues = new JObject();
        foreach (var n in recordsValues)
        {
            if (n.Value.Contains(","))
            {
                var stringToSplit = n.Value;
                var stringValues = stringToSplit.Split(',');
                List<string> arr = new List<string>();
                var allValues = "";
                foreach (var d in stringValues)
                {
                    var values = await _context.AttributeValues.FirstOrDefaultAsync(v => v.Key == n.Value);
                    arr.Add(values != null ? values.Description : d);
                    allValues = string.Join(",", arr);
                }
                jObjectValues.Add(n.Attribute, allValues);
            }
            else
            {
                var values = await _context.AttributeValues.FirstOrDefaultAsync(v => v.Key == n.Value);
                jObjectValues.Add(n.Attribute, values != null ? values.Description : n.Value);
            }
            i.GenericData = jObjectValues;
        }

您不需要对 Jobject 进行排序,您可以这样做:

var queryRecords = attributes.Select(l => new
    {
        RecordId = l.RecordId,
        ProjectId = l.ProjectId,
        Attribute = l.Attribute.Description,
        Value = l.Value,
        InfoId = l.InfoId
    }).OrderBy(o => o.Attribute).ToList();

希望对您有所帮助。