var mysql = require("mysql"); var pool = mysql.createPool({ host:"localhost", user:"root", password:"root", database:"mydb", port:"3306", connectionLimit:10 }); var helper = function(){ this.query = function(sql,callback){ pool.getConnection(function(err,conn){ if(err)console.log("获取连接失败,%s",err); conn.query(sql,function(err,rows,fields){ if(err)console.log("查询失败,%s",err); callback(rows); }); conn.release(); }); }; this.insert = function(sql,callback){ pool.getConnection(function(err,conn){ if(err)console.log("获取连接失败,%s",err); conn.query(sql,function(err,res){ if(err)console.log("新增失败,%s",err); callback(res.insertId); }); conn.release(); }); }; this.update = function(sql,callback){ pool.getConnection(function(err,conn){ if(err)console.log("获取连接失败,%s",err); conn.query(sql,function(err,res){ if(err)console.log("修改失败,%s",err); //callback(res.changedRows); callback(res.affectedRows); }); conn.release(); }) }; this.delete = function(sql,callback){ pool.getConnection(function(err,conn){ if(err)console.log("获取连接失败,%s",err); conn.query(sql,function(err,res){ if(err)console.log("删除失败,%s",err); callback(res.affectedRows); }); conn.release(); }) } } exports.helper = helper;
var fs = require("fs"); var express = require("express"); var app = express(); app.set("view engine","ejs"); app.set("views","../views"); var dbhelper = require("./dbhelper"); var helper = new dbhelper.helper(); var rootContext = "/test"; function wrapRootContextUrl(url){ return rootContext+url; } //静态资源托管 app.use(wrapRootContextUrl("/user"),express.static("../../nodejs-paginator")); app.get('/(test)?',function(req,res,next){ res.send("welcome!"); }); app.get(wrapRootContextUrl("/user/userList"),function(req,res,next){ var p = req.query.p; var limit = req.query.limit; var data = {currentPage:p,totalPages:0}; helper.query("select count(1) count from user_info",function(result){ if(result){ data.totalPages = Math.ceil(result[0].count/limit); //console.log("获取总数:"+data.totalPages); } helper.query("SELECT id,user_name userName,PASSWORD password FROM user_info LIMIT "+(p-1)*limit+","+limit,function(result){ data.items = result; //console.log("返回前获取:"+data.totalPages); res.render("index",data); }); }); }); app.listen(3000,function(){ console.log("服务启动"); });
<!DOCTYPE html> <html lang="en"> <head> <meta charset="UTF-8"> <title>用户列表</title> <link rel="stylesheet" href="css/bootstrap-responsive.css"> <link rel="stylesheet" href="css/bootstrap.css"> <link rel="stylesheet" href="css/documentation.css"> <link rel="stylesheet" href="css/highlight.js/sunburst.css"> <script src="lib/jquery.min.js"></script> <script src="lib/bootstrap.min.js"></script> <script src="lib/bootstrap-paginator.js"></script> </head> <body> <table border="1" style="width:300px;margin:0 auto;margin-top:10px;"> <tr> <td>ID</td> <td>UserName</td> <td>Password</td> </tr> <%for(var i = 0;i<items.length;i++){%> <tr> <td><%=items[i].id%></td> <td><%=items[i].userName%></td> <td><%=items[i].password%></td> </tr> <%}%> </table> <div id="example"></div> <script type="text/javascript"> var options = { currentPage:"<%=currentPage%>", totalPages:"<%=totalPages%>", size:"large", alignment:"center", itemContainerClass: function (type, page, current) { return (page === current) ? "active" : "pointer-cursor"; }, onPageClicked: function(e,originalEvent,type,page){ //alert("Page item clicked, type: "+type+" page: "+page); }, onPageChanged: function(e,oldPage,newPage){ //alert("Current page changed, old: "+oldPage+" new: "+newPage); }, pageUrl:function(type,page,current){ return "/Test/user/userlist?p="+page+"&limit=5"; } } $("#example").bootstrapPaginator(options); </script> </body> </html>
相关推荐
这是一个vue+nodejs+express+mybatis够成的一个项目案例
本文主要介绍NodeJS+Express+Mysql 实现POST和GET请求的增删改查,后续会在博客发布详细说明,可以关注一下
nodejs + express + ejs + mongodb 一个非常简单的前后端开发的实例
nodejs+Express+mssql,SQL Server实现增删改查
>本文主要介绍NodeJS+Express+Mysql实现用户登录和注册。此登录注册的方式为get
自己电脑需要安装mongodb数据库 和mongoose ,自己在用的时候,记得要和对应数据库和表名一致
基于vue2+Mysql+nodejs+express+element-ui的前后端分离图书管理系统 使用步骤: 本地运行方法  1.新建一个名为books_manage_system的数据库  2.将node目录下books_manage_system.sql文件导入到该数据库...
基于Nodejs+Express+Mongodb的记账本后端系统源码(课程设计).zip基于Nodejs+Express+Mongodb的记账本后端系统源码(课程设计).zip基于Nodejs+Express+Mongodb的记账本后端系统源码(课程设计).zip基于Nodejs+Express+...
基于NodeJS+Express+mongoDB+Bootstrap的全栈式工程化开发前后端分离博客系统实战
管理系统系列--Nodejs + Express + Ejs + Mysql 后台管理系统
图书管理系统,java+express+mongodb+nodejs+gulp.zip 图书管理系统,java+express+mongodb+nodejs+gulp.zip 图书管理系统,java+express+mongodb+nodejs+gulp.zip 图书管理系统,java+express+mongodb+nodejs+...
vue+nodejs+express+mybatis and vue+nodejs+express+mybatis资源分享
Vite + Vue3 + ts 注册登录页面书写 搭配Nodejs + Express + postgresql接口 预览:http://dongnan185.com:8083/videos/vue3.mp4 一共两个包: 一个接口包 连的本地postgresql 表及信息有截图 库自己装 一个vue包 ...
nodejs + express + mongoose demo and documents
毕业设计,基于NodeJs+Express+Mysql开发的学生社团活动管理系统,内含NodeJS完整源代码,数据库脚本 基于NodeJs+Express+Mysql学生社团活动管理系统 开发技术:nodejs + express + ElementUI + layui 开发工具...
基于nodejs+express+angularjs+mysql实现的自主学习与考试系统.zip 基于nodejs+express+angularjs+mysql实现的自主学习与考试系统.zip 基于nodejs+express+angularjs+mysql实现的自主学习与考试系统.zip 基于nodejs+...
NodeJS+express如何新建一个自己需要的项目 说明文字如下: https://blog.csdn.net/qq_38209578/article/details/82593591
文件上传是一个比较常见的功能,传统的选择方式的上传比较麻烦,需要先点击上传按钮,然后再找到文件的路径,然后上传。给用户体验带来很大问题。...结合html5、nodejs express实现了拖拽上传的功能。
简单的基于nodeJs+express+socket.io的即时通信web聊天室,实现了在线统计,消息广播 ,图片发送,表情发送等
nodejs+express入门小例子,掌握nodejs+express的模块化开发以及基本属性