后端

const Koa = require('koa2');
const Router = require('koa-router');
const Monk = require('monk');//链接mongodb数据库中间件
const app = new Koa();
const router=new Router();
const db=new Monk('localhost/school');
const students = db.get('article');
const bodyParser = require('koa-bodyparser')//解析请求参数中间件
app.use(bodyParser())
app.use(async (ctx, next) => {
console.log(`请求信息:\n 方式: ${ctx.request.method} \n 地址:${ctx.request.url}...`);
ctx.set("Access-Control-Allow-Origin", "*");
await next();//相当于java的filter放行
});
router
.get('/', async ( ctx ) => {
ctx.response.type = 'text/html';
ctx.body = 'hi'
})
.post('/vueDemo/getStudents', async ( ctx ) => {
let totle = await students.count();//表总记录数
//koa-bodyparser解析前端参数
let reqParam= ctx.request.body;//
let page = Number(reqParam.page);//当前第几页
let size = Number(reqParam.size);//每页显示的记录条数
//显示符合前端分页请求的列表查询
let options = { "limit": size,"skip": (page-1)*size};
let st = await students.find({},options,function(err,docs){
if (err) {console.log(err);return;}
else{console.log(docs);return;}
});
//是否还有更多
let hasMore=totle-(page-1)*size>size?true:false;
ctx.response.type = 'application/json';
//返回给前端
ctx.body = {hasMore:hasMore,students:st,totle:totle};
})
app.use(router.routes());
app.listen(3000, () => {
console.log('[myapp]已经运行,端口为300')
})

数据库

{"name" : "小明","age" : 10.0}
{"name" : "丁少华", "age" : 20}
{"name" : "小张","age" : 18.0}
{"name" : "王新","age" : 30.0}
{"name" : "小红","age" : 16.0}

前端

<template>
<div class="artList" >
<!--列表-->
<ul class="content">
<li v-for="st in students">
<div>{{st.name}}</div>
<div>{{st.age}}</div>
</li>
</ul>
<!--分页-->
<div class="pageinfo">
共{{totle}}条记录
<button v-on:click="fy('s')">上一页</button>
<button v-on:click="fy('x')" >下一页</button>
当前第{{page}}页
</div>
</div>
</template>
<script>
export default {
name:'artlistCmp',
data() {return { page:1,totle:0,students:[],hasMore:false,title:''}},
methods:{
getStudent(){
var vm=this;
this.service.getStudent({page:vm.page,size:3}).then(function(rep) {
vm.totle=rep.data.totle;
vm.students=rep.data.students;
vm.hasMore=rep.data.hasMore;
})
},
fy(param){
if(param=='x'){
if(!this.hasMore){alert('已经是最后一页了'); return false;}
this.page++
}else{
if(this.page==1){ alert('已经是首页了');return false; }
this.page--
}
this.getStudent()
}
},
created(){this.getStudent();}
}
</script>
<style>
.artList{width: 100%}
.list{width: 100%}
li{
display: block;
height: 140px;
background-color: aliceblue;
margin-bottom: 20px;
}
</style>

效果

vue2+koa2+mongodb分页的更多相关文章

  1. MongoDB 分页查询的方法及性能

    最近有点忙,本来有好多东西可以总结,Redis系列其实还应该有四.五.六...不过<Redis in Action>还没读完,等读完再来总结,不然太水,对不起读者. 自从上次Redis之后 ...

  2. 基于vue2.0的分页组件开发

    今天安排的任务是写基于vue2.0的分页组件,好吧,我一开始是觉得超级简单的,但是越写越写不出来,写的最后乱七八糟的都不知道下句该写什么了,所以重新捋了思路,小结一下- 首先写组件需要考虑: 要从父组 ...

  3. C#MongoDB 分页查询的方法及性能

    传统的SQL分页 传统的sql分页,所有的方案几乎是绕不开row_number的,对于需要各种排序,复杂查询的场景,row_number就是杀手锏.另外,针对现在的web很流行的poll/push加载 ...

  4. vue2.0实现分页组件

    最近使用vue2.0重构项目, 需要实现一个分页的表格, 没有找到合适的组件, 就自己写了一个, 效果如下: 该项目是使用 vue-cli搭建的, 如果你的项目中没有使用webpack,请根据代码自己 ...

  5. 基于 Vue + Koa2 + MongoDB + Redis 实现一个完整的登录注册

    项目地址:https://github.com/caochangkui/vue-element-responsive-demo/tree/login-register 通过 vue-cli3.0 + ...

  6. MongoDB分页的Java实现和分页需求的思考

    前言 传统关系数据库中都提供了基于row number的分页功能,切换MongoDB后,想要实现分页,则需要修改一下思路. 传统分页思路 假设一页大小为10条.则 //page 1 1-10 //pa ...

  7. mongodb分页

    1 什么是mongodb的分页 就是一次返回表中的连续若干行. 2 什么是sql分页 同样是返回表中的连续若干行. 3 如何实现sql分页 利用order by xxx limit xxx 4 如何实 ...

  8. 基于node+koa2+mongodb实现简单的导航管理系统

    基于node+koa2+mongodb实现简单的导航管理系统 项目说明 本项目gitbub地址 https://github.com/xuess/nav-admin,喜欢请star 基于node 实现 ...

  9. MongoDB分页查询优化方法

    在网上看到很多关于MongoDB分页查询优化的文章,如出一辙.笔者自己实际生产中也遇到此问题,所以看了很多篇文章,这里分享一篇简明扼要的文章分享给大家,希望对大家在使用MongoDB时有所帮助. 凡事 ...

随机推荐

  1. redis是如何存储对象和集合的

    在项目中,缓存以及mq消息队列可以说是不可或缺的2个重要技术.前者主要是为了减轻数据库压力,大幅度提升性能.后者主要是为了提高用户的体验度,我理解的是再后端做的一个ajax请求(异步),并且像ribb ...

  2. ChemDraw Pro绘制无环链结构的两种方法

    ChemDraw Pro 14是一款专门针对化学图形绘制而开发制作的编辑软件,是目前工科类常用的绘制化学结构工具,用于快速绘制常用的环结构组成.以下教程讲解ChemDraw Pro绘制无环链结构的两种 ...

  3. JAVA增删改查XML文件

    最近总是需要进行xml的相关操作. 不免的要进行xml的读取修改等,于是上网搜索,加上自己的小改动,整合了下xml的常用操作. 读取XML配置文件 首先我们需要通过DocumentBuilderFac ...

  4. 如何用sql语句复制一张表

    如何用sql语句复制一张表 1.复制表结构及数据到新表 CREATE TABLE 新表 SELECT * FROM 旧表 这种方法会将oldtable中所有的内容都拷贝过来,当然我们可以用delete ...

  5. HYSBZ 1036(树的统计Count)

    题目链接:传送门 题目大意:中文题,略 题目思路:树链剖分裸题. 闲谈:树链越练越熟练了 #include <iostream> #include <cstdio> #incl ...

  6. [SharePoint 2010]Sandboxed Solution (沙箱解決方案)

    現有的SharePoint 2007系統中,我們如果要安裝客製化的程式碼到系統中,我們必須製作一個解決方案包裝檔(Solution Package),然後在系統的中央管理後台中,真對整個伺服器農場Fa ...

  7. Bootstrap初学基础总结

    Bootstrap 1>.Web UI 框架 可以帮助菜鸟程序员 ,迅速简便的搭建起专业级界面效果 2>如何快速掌握利用框架 1.框架的整合和搭建,让框架能够正常跑起来 2.通过复制粘贴文 ...

  8. Python全栈day10(运算符)

    一,运算符 + - * . ** % // 二,in 和not in 一个字符串包含多个字符可以通过in判断字符是否属于改字符串 >>> name = "zhangsan& ...

  9. 使用RODBC连接MySQL数据库(R-3.4.3)

    1.安装RODBC包 install.packages("RODBC") 2.配置ODBC 首先查看是否有mysqlODBC5.1Driver  如果没有mysqlODBC5.1D ...

  10. (转)android mock location

    android mock location 2014-01-26     我来说两句   来源:党玉涛   收藏 我要投稿 现在软件市场上有很多可以改变手机地理位置的软件,更改后打开微信就可以随意定位 ...