PagetList <t>的Newtonsoft.Json序列化不包括一些属性</t>

时间:2012-06-03 13:09:25

标签: json json.net pagedlist

我正在尝试将PagedList对象(https://github.com/martijnboland/MvcPaging/blob/master/src/MvcPaging/PagedList.cs)序列化为Json,如下所示:

PagedList<Product> pagedList = new PagedList<Product>(products, (page - 1), pageSize);
string json = Newtonsoft.Json.JsonConvert.SerializeObject(pagedList);

如果我使用上面的代码,在结果中我得到一个正确序列化的Product对象数组。但是,以下属性(PagedList)不包含在Json结果中:

    public bool HasNextPage { get; }
    public bool HasPreviousPage { get; }
    public bool IsFirstPage { get; }
    public bool IsLastPage { get; }
    public int ItemEnd { get; }
    public int ItemStart { get; }
    public int PageCount { get; }
    public int PageIndex { get; }
    public int PageNumber { get; }
    public int PageSize { get; }
    public int TotalItemCount { get; }

它们没有被序列化,但它们是PagedList的一部分。

有谁知道为什么?我怎么能在序列化中包含这些属性?

由于

4 个答案:

答案 0 :(得分:9)

序列化程序看到PagedList是可枚举的,因此它将其序列化为JavaScript数组。为了使这更容易处理,我在PagedList对象上公开了一个GetMetaData()函数,该函数将返回一个MetaData对象,该对象包含上面提到的字段。这意味着您可以像这样序列化您的页面列表:

string json = Newtonsoft.Json.JsonConvert.SerializeObject(new{
  items = pagedList,
  metaData = pagedList.GetMetaData()
});

这应该会产生一个像这样的JSON对象:

{
    "Items": [
        { ... },
        { ... },
        { ... }
    ],
    "MetaData": {
        "PageSize": 1,
        "PageCount": 2,
        "HasNextPage": true,
        ...
    }
}

答案 1 :(得分:0)

有一个jquery插件,用于激动地执行此操作:

https://github.com/turhancoskun/pagify.mvc

<script type="text/javascript">
$(function() {
    $('#users').pagify({
        dataUrl: '/User/UserLis',
        callBack: function(){
           // Ajax remove preloader and some other callbacks  
        },
        beforeSend: function(){
           // Ajax show preloader and some other function before start
        }
    });
}
</script>

readme.md文件包含一个示例

答案 2 :(得分:0)

要序列化,只需使用Troy的实现。但要反序列化创建2个新类:

public class PaginationEntity<TEntity> where TEntity : class 
{
    public PaginationEntity()
    {
        Items = new List<TEntity>();
    }
    public IEnumerable<TEntity> Items { get; set; }
    public PaginationMetaData MetaData { get; set; }
}

public class PaginationMetaData
{
    public int Count { get; set; }
    public int FirstItemOnPage { get; set; }
    public bool HasNextPage { get; set; }
    public bool HasPreviousPage { get; set; }
    public bool IsFirstPage { get; set; }
    public bool IsLastPage { get; set; }
    public int LastItemOnPage { get; set; }
    public int PageCount { get; set; }
    public int PageNumber { get; set; }
    public int PageSize { get; set; }
    public int TotalItemCount { get; set; }
}

并以这种方式反序列化:

PaginationEntity<TEntity> listPaginated = JsonConvert.DeserializeObject<PaginationEntity<TEntity>>(json)

你很高兴。

答案 3 :(得分:0)

默认情况下,asp.core使用DataContractSerializer,因此任何人都可以将[DataContract][DataMember]设置为Product类和成员,并通过以下操作获取所需的数据:

 public IActionResult Products(int page=1,int countPerPage=10)
    {
        var result = _dbContext.Products.AsNoTracking().ToPagedList(page, countPerPage);

        return Ok( new{result, total=result.TotalItemCount });
    }

无需使用Newtonsoft.Json