当前位置: 首页 » 产品 » 家居百货 » 正文

nodejs个人博客数据分页开发教程

放大字体  缩小字体 发布日期: 2024-10-02 18:28   来源:http://www.baidu.com/  作者:无忧资讯  浏览次数:12
核心提示:  */  var router=express.Router();    var pageSize=4;    router.get('http://www.3lian.com/',function(req,res

  */

  var router=express.Router();

  

  var pageSize=4;

  

  router.get('http://www.3lian.com/',function(req,res,next){

  var cid=0;

  F.model("article").assignIndexData(cid,1,pageSize,res);

  });

  

  router.get('/index/:page',function(req,res,next){

  var currentPage=parseInt(req.params.page);

  var cid=0;

  F.model("article").assignIndexData(cid,currentPage,pageSize,res);

  });

  分类列表分页路由::8888/category/分类id/分页

  

  router.get('/category/:cid/:page',function(req,res,next){

  var cid=req.params.cid;

  var currentPage=parseInt(req.params.page);

  F.model("article").assignIndexData(cid,currentPage,pageSize,res);

  });

  模型数据部分

  控制器调用article模型的assignIndexData()方法,参数:分类id,当前页,每页条数,响应对象

  调用category模型的getAllList()方法得到分类list,参数:回调函数

  调用article模型的getCount()方法得到总条数,参数:分类id,回调函数

  调用article模型的getArticlePager()方法得到文章对象的数据list,参数:分类id,当前页,每页条数,回调函数

  对上一页,下一页进行-1和+1,并进行判断,上一页应大于0,下一页应小于等于总页数(总条数/每页条数 向上取整)

  把数据分配到模板上

  

  module.exports={

  

  getCount:function(categoryId,callback){

  var condition="";

  if(categoryId!=0){

  condition="where category_id="+categoryId;

  }

  var sql="select count(*) num from article "+condition;

  db.query(sql,callback);

  },

  

  getArticlePager:function(categoryId,currentPage,pageSize,callback){

  if(currentPage<=0||!currentPage) currentPage=1;

  var start=(currentPage-1)*pageSize;

  var end=pageSize;

  var condition="";

  if(categoryId!=0){

  condition="where category_id="+categoryId;

  }

  var sql="select * from article "+condition+" order by time desc limit "+start+","+end;

  db.query(sql,callback);

  },

  

  getArchives:function(callback){

  db.query("select time from article order by time desc",callback);

  },

  

  assignIndexdata:function(cid,currentPage,pageSize,res){

  var categoryModel=F.model("category");

  var articleModel=this;

  // 分类数据

  categoryModel.getAllList(function(err,categoryList){

  // 文章条数

  articleModel.getCount(cid,function(err,nums){

  // 文章分页

  articleModel.getArticlePager(cid,currentPage,pageSize,function(err,articleList){

  var nextPage=(currentPage+1)>=Math.ceil(nums[0].num/pageSize) ? Math.ceil(nums[0].num/pageSize) : currentPage+1;

  var prePage=(currentPage-1)<=0 ? 1 : currentPage-1;

  // 归档

  articleModel.getArchives(function(err,allArticleTime){

  var newArticleTime=[];

  for(var i=0;i

  newArticleTime.push(F.phpDate("y年m月",allArticleTime[i].time));

  }

  

  var data={

  categoryList:categoryList,

  articleList:articleList,

  cid:cid,

  nextPage:nextPage==0 ? 1 : nextPage,

  prePage:prePage,

  allArticleTime:newArticleTime,

  currentPage:currentPage

  };

  

  res.render("home/index",data);

  });

  });

  });

  });

  }

  };

  模板部分

  href=http://www.jsgho.com/help/fwq/"/category//index/" rel="external nofollow" >上一页

  href=http://www.jsgho.com/help/fwq/"/category//index/" rel="external nofollow" >下一页

  效果图:

nodejs个人博客数据分页开发教程 三联

nodejs个人博客数据分页开发教程

 
 
[ 产品搜索 ]  [ 加入收藏 ]  [ 告诉好友 ]  [ 打印本文 ]  [ 违规举报 ]  [ 关闭窗口 ]

 

 
推荐图文
推荐产品
点击排行
    行业协会  备案信息  可信网站