无为清净楼资源网 Design By www.qnjia.com
MVC新闻网站建立,完成分页查询数据功能。
1、在Model里面建立NewInfo(里面存放的是新闻信息的实体信息)
然后在DAL层中建立NewInfoDal (里面存放对新闻信息的操作)
写入分页查询的代码
/// <summary> /// 分页查询 /// </summary> /// <param name="start">分页开始条数</param> /// <param name="end">分页结束条数</param> /// <returns>返回查询到的list集合</returns> public List<NewInfo> GetPageEntityList(int start,int end) { string sql = "select * from(select row_number()over(order by id)as num,*from T_News)as t where t.num>=@start and t.num<=@end"; SqlParameter[] pms = { new SqlParameter("@start",SqlDbType.Int), new SqlParameter("@end",SqlDbType.Int), }; pms[0].Value = start; pms[1].Value = end; DataTable dt = SqlHelper.ExcuteDataTable(sql,CommandType.Text,pms); List<NewInfo> newList = null; if (dt.Rows.Count>0) { newList = new List<NewInfo>(); NewInfo newinfo = null; foreach (DataRow item in dt.Rows) { newinfo = new NewInfo(); LoadEntity(item,newinfo); newList.Add(newinfo); } } return newList; } /// <summary> /// 查询出页面条数 /// </summary> /// <returns></returns> public int GetRecordCount() { string sql = "select count(*) from T_News"; int count = Convert.ToInt32(SqlHelper.ExecuteScalar(sql,CommandType.Text)); return count; }
在BLL层中建立NewInfoServices(里面存放对新闻信息的逻辑处理)
DAL.NewInfoDal NewInfoDal = new DAL.NewInfoDal(); /// <summary> /// 分页查询数据 /// </summary> /// <param name="pageIndex">当前页码值</param> /// <param name="pageSize">一个多少条数据</param> /// <returns></returns> public List<NewInfo> GetPageEntityList(int pageIndex, int pageSize) { int start = (pageIndex - 1) * pageSize + 1; int end = pageSize * pageIndex; return NewInfoDal.GetPageEntityList(start,end); } /// <summary> /// 查询出页面的记录数 /// </summary> /// <returns></returns> public int GetRecordCount() { return NewInfoDal.GetRecordCount(); }
我们把新闻管理的url指定为/NewInfo/Index
那么就要新建NewInfo控制器 Index视图就是新闻管理页面的主页了。
新闻管理主页的布局很简单就是一个表格,所以就先在body里面写了一表格
<body> <div> <table id="tt"></table> </div> </body/>
这里用到的是easyui的框架,所以先引用文件。
然后就是通过写js代码来显示出表格的行和列
<script type="text/javascript"> $(function () { //初始化表格 initTable(); }); //初始化表格 function initTable() { $("#tt").datagrid({ //指向一个地址,当表格加载完成后自动请求该地址 //自动向后台发送 rows 当前页多少条数据 page:当前页 //要求返回的数据json对象 {total:200,rows:[{},{}]} url: '/NewInfo/ShowNewsList', title: "新闻管理", fitColumns: true, height: $(window).height()-10, idField: 'Id', //后台返回数据中的主键列。一定注意大小写。 loadMsg: "正在加载新闻信息........", pagination: true, //启用分页 singleSelect: true, //只允许选中一行 pageSize: 10, //一页默认多少条 pageNumber: 1, //默认页 rownumbers: true,//行号 pageList: [10, 20, 30], //允许一页多少条数据 queryParams: {}, //异步请求可以额外传递的数据 columns: [[ { field: 'ck', checkbox: true, align: 'left', width: 50 }, // 设置cheakbox { field: 'Title', title: '标题', width: 120 }, { field: 'SubDateTime', title: '发布时间', width: 80, formatter: ChangeDateFormat, }, { field: 'Author', title: '作者', width: 80 }, { field: 'operate', title: '操作', align: 'center', width: $(this).width() * 0.1, formatter: function (value, row, index) { var str = ""; str += '<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" name="detail" id="detail" class="easyui-linkbutton" onclick="showDetail('+row.Id+')"></a>'; str += ' ', str += '<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" name="update" id="update" class="easyui-linkbutton" onclick="updateNewInfo(' + row.Id + ')" ></a>'; str += ' ', str += '<a href="#" rel="external nofollow" rel="external nofollow" rel="external nofollow" name="delete" id="delete" class="easyui-linkbutton" onclick="deleteNewInfo(' + row.Id + ')" ></a>'; return str; } } ]], onLoadSuccess: function (data) { $("a[name='detail']").linkbutton({ text: '详情', plain: true, iconCls: 'icon-more' }); $("a[name='update']").linkbutton({ text: '编辑', plain: true, iconCls: 'icon-edit' }); $("a[name='delete']").linkbutton({ text: '删除', plain: true, iconCls: 'icon-cancel' }); ////点击详情按钮 //clickDetail(); }, toolbar: [{ id: 'btnAdd', text: '添加', iconCls: 'icon-add', handler: function () { addBtnClick(); //添加新闻 } }], }); }
要完成数据的显示则还需要查询数据库。
根据 url: '/NewInfo/ShowNewsList', 所以需要在NewInfo控制器下建立ShowNewsList方法
/// <summary> /// 分页展示数据 /// </summary> /// <returns></returns> public JsonResult ShowNewsList() { //要求返回的数据json对象 {total:200,rows:[{},{}]} int pageSize = int.Parse(Request["rows"]"10"); int pageIndex = int.Parse(Request["page"]"1"); List<NewInfo> newInfoList= NewInfoBll.GetPageEntityList(pageIndex, pageSize); //查询所有数据 var allNews = NewInfoBll.GetRecordCount(); //把totle和rows:[{},{}]一起返回 //先建立一个匿名类 var dataJson = new { total = allNews, rows = newInfoList }; var json = Json(dataJson, JsonRequestBehavior.AllowGet); return json; }
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
标签:
MVC,新闻网站,分页查询
无为清净楼资源网 Design By www.qnjia.com
广告合作:本站广告合作请联系QQ:858582 申请时备注:广告合作(否则不回)
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
免责声明:本站文章均来自网站采集或用户投稿,网站不提供任何软件下载或自行开发的软件! 如有用户或公司发现本站内容信息存在侵权行为,请邮件告知! 858582#qq.com
无为清净楼资源网 Design By www.qnjia.com
暂无评论...
RTX 5090要首发 性能要翻倍!三星展示GDDR7显存
三星在GTC上展示了专为下一代游戏GPU设计的GDDR7内存。
首次推出的GDDR7内存模块密度为16GB,每个模块容量为2GB。其速度预设为32 Gbps(PAM3),但也可以降至28 Gbps,以提高产量和初始阶段的整体性能和成本效益。
据三星表示,GDDR7内存的能效将提高20%,同时工作电压仅为1.1V,低于标准的1.2V。通过采用更新的封装材料和优化的电路设计,使得在高速运行时的发热量降低,GDDR7的热阻比GDDR6降低了70%。
更新日志
2024年11月16日
2024年11月16日
- 《怪猎荒野》PS5Pro主机版对比:B测性能都不稳定
- 黄宝欣.1992-黄宝欣金装精选2CD【HOMERUN】【WAV+CUE】
- 群星.1996-宝丽金流行爆弹精丫宝丽金】【WAV+CUE】
- 杜德伟.2005-独领风骚新歌精选辑3CD【滚石】【WAV+CUE】
- 安与骑兵《心无疆界》[低速原抓WAV+CUE]
- 柏菲唱片-群星〈胭花四乐〉2CD[原抓WAV+CUE]
- 金典女声发烧靓曲《ClassicBeautifulSound》2CD[低速原抓WAV+CUE]
- 王杰1992《封锁我一生》粤语专辑[WAV+CUE][1G]
- 群星《一人一首成名曲 (欧美篇)》6CD[WAV/MP3][7.39G]
- 东来东往2004《回到我身边·别说我的眼泪你无所谓》先之唱片[WAV+CUE][1G]
- MF唱片-《宝马[在真HD路上]》2CD[低速原抓WAV+CUE]
- 李娜《相信我》新时代[WAV+CUE]
- 2019明达发烧碟MasterSuperiorAudiophile[WAV+CUE]
- 蔡幸娟.1993-相爱容易相处难【飞碟】【WAV+CUE】
- 陆虎.2024-是否愿意成为我的全世界【Hikoon】【FLAC分轨】