Heim  >  Artikel  >  Backend-Entwicklung  >  javascript - 关于nodejs做文章分页的方式,怎么获取到翻页的总数值?

javascript - 关于nodejs做文章分页的方式,怎么获取到翻页的总数值?

WBOY
WBOYOriginal
2016-08-04 09:20:141211Durchsuche

<code>router.get("/:page",function(req,res){
    if(req.params.page == 0){
        res.send("<div style="font-size:16px;font-weight:bold;color:red">404</div>");
    }
    conn.query("select * from news_base",function(err,pdata){
        conn.query("select * from news_base limit "+(req.params.page-1)*3+",3",function(err,data){
            res.render("admin/list",{datas : pdata,pageDatas : data});
        });
    });
});
</code>

select * from news_base limit 这条sql是根据页数获取具体的数据。
可是在前台页面 我要做一个翻页的 “上一页 1.2.3.4.5 下一页”的效果,那就要知道数据的总和才能计算。但是 select * from news_base limit 这个sql获取不到数据的总和数。

所以只好再写一条sql “select * from news_base ” 这个就可以返回一个数组。然后通过length就可以拿到总数值来计算。

但是两条sql感觉很多余一样。。感觉代码很臃肿。。
还有没有更好的方法来实现翻页的效果。
前台用的是ejs模板引擎。

回复内容:

<code>router.get("/:page",function(req,res){
    if(req.params.page == 0){
        res.send("<div style="font-size:16px;font-weight:bold;color:red">404</div>");
    }
    conn.query("select * from news_base",function(err,pdata){
        conn.query("select * from news_base limit "+(req.params.page-1)*3+",3",function(err,data){
            res.render("admin/list",{datas : pdata,pageDatas : data});
        });
    });
});
</code>

select * from news_base limit 这条sql是根据页数获取具体的数据。
可是在前台页面 我要做一个翻页的 “上一页 1.2.3.4.5 下一页”的效果,那就要知道数据的总和才能计算。但是 select * from news_base limit 这个sql获取不到数据的总和数。

所以只好再写一条sql “select * from news_base ” 这个就可以返回一个数组。然后通过length就可以拿到总数值来计算。

但是两条sql感觉很多余一样。。感觉代码很臃肿。。
还有没有更好的方法来实现翻页的效果。
前台用的是ejs模板引擎。

sql select的时候是可以使用count的,自己查一下相关用法吧。

总数得占用一条sql,用select count(*) from news_base 获取总数吧。

表明上两次SELECT实际只查询一次的方法

<code>SELECT SQL_CALC_FOUND_ROWS  * FROM apps limit 2,6;
SELECT FOUND_ROWS();//在得到数据后,通过FOUND_ROWS()可以得到不带LIMIT的结果数:

</code>

但是SQL_CALC_FOUND_ROWS在速度上会比COUNT(*)慢~

如果没有过滤条件 可以把列表总数单独存下来 内存缓存一下后随列表吐出。

可以首次进入页面时候发出两个请求:一个请求总数量,一个请求limit行。
总数量记录在页面中。
之后翻页的话只发第二个请求即可。

只需要总数量的情况也是存在的,应该考虑单独开发这个接口。

如果不考虑初次加载网络开销大的问题的话,可以直接全部拉到本地,在客户端做分页。

Stellungnahme:
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn