*惯,先上个效果图:
1、在IBLL
在InterfaceCommonModelService接口中添加获取公共模型列表的方法
首先排序方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
|
/// < summary >
/// 排序
/// </ summary >
/// < param name = "entitys" >数据实体集</ param >
/// < param name = "roderCode" >排序代码[默认:ID降序]</ param >
/// < returns ></ returns >
IQueryable< CommonModel > Order(IQueryable< CommonModel > entitys, int roderCode);
查询数据方法
/// < summary >
/// 查询分页数据列表
/// </ summary >
/// < param name = "totalRecord" >总记录数</ param >
/// < param name = "model" >模型【All全部】</ param >
/// < param name = "pageIndex" >页码</ param >
/// < param name = "pageSize" >每页记录数</ param >
/// < param name = "title" >标题【不使用设置空字符串】</ param >
/// < param name = "categoryID" >栏目ID【不使用设0】</ param >
/// < param name = "inputer" >用户名【不使用设置空字符串】</ param >
/// < param name = "fromDate" >起始日期【可为null】</ param >
/// < param name = "toDate" >截止日期【可为null】</ param >
/// < param name = "orderCode" >排序码</ param >
/// < returns >分页数据列表</ returns >
IQueryable< CommonModel > FindPageList(out int totalRecord, int pageIndex, int pageSize, string model, string title, int categoryID, string inputer, Nullable< DateTime > fromDate, Nullable< DateTime > toDate, int orderCode);
|
2、BLL
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
|
在CommonModelService写方法实现代码,内容都很简单主要是思路,直接上代码
public IQueryable< CommonModel > FindPageList(out int totalRecord, int pageIndex, int pageSize, string model, string title, int categoryID, string inputer, Nullable< DateTime > fromDate, Nullable< DateTime > toDate, int orderCode)
{
//获取实体列表
IQueryable< CommonModel > _commonModels = CurrentRepository.Entities;
if (model == null || model != "All") _commonModels = _commonModels.Where(cm => cm.Model == model);
if (!string.IsNullOrEmpty(title)) _commonModels = _commonModels.Where(cm => cm.Title.Contains(title));
if (categoryID > 0) _commonModels = _commonModels.Where(cm => cm.CategoryID == categoryID);
if (!string.IsNullOrEmpty(inputer)) _commonModels = _commonModels.Where(cm => cm.Inputer == inputer);
if (fromDate != null) _commonModels = _commonModels.Where(cm => cm.ReleaseDate >= fromDate);
if (toDate != null) _commonModels = _commonModels.Where(cm => cm.ReleaseDate <= toDate);
_commonModels = Order(_commonModels, orderCode);
totalRecord = _commonModels.Count();
return PageList(_commonModels, pageIndex, pageSize).AsQueryable();
}
public IQueryable< CommonModel > Order(IQueryable< CommonModel > entitys, int orderCode)
{
switch(orderCode)
{
//默认排序
default:
entitys = entitys.OrderByDescending(cm => cm.ReleaseDate);
break;
}
return entitys;
}
|
3、web
由于CommonModel跟我们前台显示的数据并不一致,为了照顾datagrid中的数据显示再在Ninesky.Web.Models中再构造一个视图模型CommonModelViewModel
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
|
using System;
namespace Ninesky.Web.Models
{
/// < summary >
/// CommonModel视图模型
/// < remarks >
/// 创建:2014.03.10
/// </ remarks >
/// </ summary >
public class CommonModelViewModel
{
public int ModelID { get; set; }
/// < summary >
/// 栏目ID
/// </ summary >
public int CategoryID { get; set; }
/// < summary >
/// 栏目名称
/// </ summary >
public string CategoryName { get; set; }
/// < summary >
/// 模型名称
/// </ summary >
public string Model { get; set; }
/// < summary >
/// 标题
/// </ summary >
public string Title { get; set; }
/// < summary >
/// 录入者
/// </ summary >
public string Inputer { get; set; }
/// < summary >
/// 点击
/// </ summary >
public int Hits { get; set; }
/// < summary >
/// 发布日期
/// </ summary >
public DateTime ReleaseDate { get; set; }
/// < summary >
/// 状态
/// </ summary >
public int Status { get; set; }
/// < summary >
/// 状态文字
/// </ summary >
public string StatusString { get { return Ninesky.Models.CommonModel.StatusList[Status]; } }
/// < summary >
/// 首页图片
/// </ summary >
public string DefaultPicUrl { get; set; }
}
}
|
在ArticleController中添加一个返回json类型的JsonList方法
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
|
/// < summary >
/// 文章列表Json【注意权限问题,普通人员是否可以访问?】
/// </ summary >
/// < param name = "title" >标题</ param >
/// < param name = "input" >录入</ param >
/// < param name = "category" >栏目</ param >
/// < param name = "fromDate" >日期起</ param >
/// < param name = "toDate" >日期止</ param >
/// < param name = "pageIndex" >页码</ param >
/// < param name = "pageSize" >每页记录</ param >
/// < returns ></ returns >
public ActionResult JsonList(string title, string input, Nullable< int > category, Nullable< DateTime > fromDate, Nullable< DateTime > toDate, int pageIndex = 1, int pageSize = 20)
{
if (category == null) category = 0;
int _total;
var _rows = commonModelService.FindPageList(out _total, pageIndex, pageSize, "Article", title, (int)category, input, fromDate, toDate, 0).Select(
cm => new Ninesky.Web.Models.CommonModelViewModel()
{
CategoryID = cm.CategoryID,
CategoryName = cm.Category.Name,
DefaultPicUrl = cm.DefaultPicUrl,
Hits = cm.Hits,
Inputer = cm.Inputer,
Model = cm.Model,
ModelID = cm.ModelID,
ReleaseDate = cm.ReleaseDate,
Status = cm.Status,
Title = cm.Title
});
return Json(new { total = _total, rows = _rows.ToList() });
}
|
下面是做界面了,在添加 List方法,这里不提供任何数据,数据在JsonList 中获得
1
2
3
4
5
6
7
8
|
/// < summary >
/// 全部文章
/// </ summary >
/// < returns ></ returns >
public ActionResult List()
{
return View();
}
|
右键添加视图
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
< div id = "toolbar" >
< div >
< a href = "#" class = "easyui-linkbutton" data-options = "iconCls:'icon-edit',plain:true" >修改</ a >
< a href = "#" class = "easyui-linkbutton" data-options = "iconCls:'icon-remove',plain:true" ">删除</ a >
< a href = "#" class = "easyui-linkbutton" data-options = "iconCls:'icon-reload',plain:true" onclick = "$('#article_list').datagrid('reload');" >刷新</ a >
</ div >
< div class = "form-inline" >
< label >栏目</ label >< input id = "combo_category" data-options = "url:'@Url.Action(" JsonTree", "Category", new { model = "Article" })'" class = "easyui-combotree" />
< label >标题</ label > < input id = "textbox_title" class = "input-easyui" style = "width:280px" />
< label >录入人</ label >< input id = "textbox_inputer" class = "input-easyui" />
< label >添加日期</ label >
< input id = "datebox_fromdate" type = "datetime" class = "easyui-datebox" style = "width:120px" /> -
< input id = "datebox_todate" type = "datetime" class = "easyui-datebox" style = "width:120px; " />
< a href = "#" id = "btn_search" data-options = "iconCls:'icon-search'" class = "easyui-linkbutton" >查询</ a >
</ div >
</ div >
< table id = "article_list" ></ table >
< script src = "~/Scripts/Common.js" ></ script >
< script type = "text/javascript" >
$("#article_list").datagrid({
loadMsg: '加载中……',
pagination:true,
url: '@Url.Action("JsonList","Article")',
columns: [[
{ field: 'ModelID', title: 'ID', checkbox: true },
{ field: 'CategoryName', title: '栏目'},
{ field: 'Title', title: '标题'},
{ field: 'Inputer', title: '录入', align: 'right' },
{ field: 'Hits', title: '点击', align: 'right' },
{ field: 'ReleaseDate', title: '发布日期', align: 'right', formatter: function (value, row, index) { return jsonDateFormat(value); } },
{ field: 'StatusString', title: '状态', width: 100, align: 'right' }
]],
toolbar: '#toolbar',
idField: 'ModelID',
});
//查找
$("#btn_search").click(function () {
$("#article_list").datagrid('load', {
title: $("#textbox_title").val(),
input: $("#textbox_inputer").val(),
category: $("#combo_category").combotree('getValue'),
fromDate: $("#datebox_fromdate").datebox('getValue'),
toDate: $("#datebox_todate").datebox('getValue')
});
});
}
</ script >
|
上面都是easyui-datagrid的内容。
总体思路是BLL中实现查询公共模型列表,web中添加一个JsonList方法调用BLL中的方法并返回列表的Json类型。然后再添加一个List调用JsonList用来显示。下篇文章做删除和修改操作,希望大家会持续关注。