这也正是我的问题。
但是我的问题是通过改变业务输出类方法的结构来解决的。
当然,这种方式你需要有数据输出和行数。
并且不要忘记与必须从数据库中获取相同页面布局数据相关的问题。
我的课程旨在执行以下操作。
using System.Collections.Generic;
using System.Linq;
using Andish.CSS.Common.Enum;
using AutoMapper;
using system.linq.dynamic;
namespace Andish.CSS.Common.Result.Implementation
{
public static class PagingResult
{
public static PageResult<K> ToPageResult<T, K>(this IQueryable<T> queryable, int rowCount,
int pageNumber, string sortField, DynamicLinqSortFieldKind
dynamicLinqSortFieldKind)
{
var allQueryRow = queryable.ToList<T>().Count();
var skipLen = (pageNumber - 1) * rowCount;
string orderKind = "";
orderKind = dynamicLinqSortFieldKind == DynamicLinqSortFieldKind.Ascending ? " Asc" : " Desc";
PageResult<K> pageResult = new PageResult<K>
{
PageNumber = pageNumber,
RowCount = rowCount,
Result = Mapper.Map<IList<K>>(queryable.OrderBy(sortField + orderKind)
.Skip(skipLen).Take(rowCount).ToList<T>()),
ResultRowCount = allQueryRow,
PageCount = allQueryRow % rowCount == 0 ? allQueryRow / rowCount : (allQueryRow / rowCount) + 1
};
return pageResult;
}
}
}
create this enum
public enum DynamicLinqSortFieldKind
{
Ascending = 0,
Descending = 1
}
并且为了使用这个扩展方法这样做,我有一个来自 ExecutiveUnit 类的结果,我想将这个类映射到另一个类 ExecutiveUnitModel 。我使用自动映射器 nuget。
var xresult = result.ToPageResult<ExecutiveUnit, ExecutiveUnitModel>(RowNumbers, pageNumber, "Code", DynamicLinqSortFieldKind.Ascending);