我正在尝试将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的一部分。
有谁知道为什么?我怎么能在序列化中包含这些属性?
由于
答案 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