Сериализация Newtonsoft.Json PagedList‹T› не включает некоторые свойства

Я пытаюсь сериализовать объект 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.

Кто-нибудь знает, почему? И как я могу включить эти свойства в сериализацию?

Спасибо


person LeoD    schedule 03.06.2012    source источник


Ответы (4)


Сериализатор видит, что PagedList можно перечислить, поэтому сериализует его в массив JavaScript. Чтобы упростить эту задачу, я предоставляю функцию GetMetaData() для объекта PagedList, которая будет возвращать объект MetaData, содержащий именно те поля, которые вы упомянули выше. Это означает, что вы можете сериализовать свой список страниц следующим образом:

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

Это должно привести к такому объекту JSON:

{
    "Items": [
        { ... },
        { ... },
        { ... }
    ],
    "MetaData": {
        "PageSize": 1,
        "PageCount": 2,
        "HasNextPage": true,
        ...
    }
}
person Troy    schedule 21.06.2012
comment
любая идея, как десериализовать - person AMH; 11.05.2014
comment
Спасибо, Трой, очень хорошая реализация. Я просто добавляю часть десериализации, как просил AMH. - person PedroSouki; 12.08.2016

есть плагин 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 содержит пример

person turhanco    schedule 12.07.2013

Для сериализации просто используйте реализацию 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)

и вы можете идти.

person PedroSouki    schedule 12.08.2016

По умолчанию asp.core использует DataContractSerializer, поэтому любой может установить [DataContract] и [DataMember] для класса и членов продукта и получить необходимые данные, выполнив следующие действия:

 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

person Lapenkov Vladimir    schedule 23.04.2019