node.js(小案例)_使用mongodb对学生信息列表优化
一、前言
1、这篇文章主要对上一篇案列在操作增删改的时候使用mongodb进行优化
2、项目源码(包含上):https://github.com/4561231/crud-express-node.git
3、参考:菜鸟教程,
https://mongoosejs.com/docs/guide.html
二、具体实现
1、关键性js代码
项目入口app.js(基本不变)
//引入express
var express = require('express');
var fs = require('fs');
//引入路由
var router = require('./router') //引入body-parse var bodyParse = require('body-parser') //创建
var app = new express();
//请求访问 //配置开放静态资源
app.use('/public/', express.static('./public/'))
app.use('/node_modules/', express.static('./node_modules/')) //用express来渲染
app.engine('html', require('express-art-template')) //配置body-parse
app.use(bodyParse.urlencoded({ extended: false}));
app.use(bodyParse.json()); //使用router
app.use(router); //设置端口
app.listen(5000, function () { console.log('server is running')
})
app.js
路由router.js
var fs = require('fs');
var express = require('express');
//加入student模块
var Student = require('./student1.js')
//express中转么提供了一种更好的方式可以用来包装路由
var router = express.Router();
//根据路径写好路由壳子
router.get('/students', function (req, res) {
Student.find(function (err, students) {
if(err) {
return res.status(500).send('Server err');
}
res.render('index.html', {
fruits: [
'苹果',
'香蕉',
'橘子'
],
students: students
})
})
});
router.get('/students/new', function (req, res){
res.render('new.html')
});
router.post('/students/new', function (req, res) {
console.log(req.body);
var sudent = new Student(req.body)
sudent.save(function (err) {
if(err) {
return res.status(500).send('Server err');
}
res.redirect('/students')
})
});
//这一次通过get到那个编辑页面
router.get('/students/edit', function (req, res) {
//调用得到的是保存之后的数据
//1.如何获取数据
//2.处理数据
//3.发送响应
//4.将数据再次写入data.json文件
console.log(req.query.id);
Student.findById(req.query.id.replace(/"/g,''), function (err, student) {
if (err) {
return res.status(500).send('Server err');
}
//console.log(student);
res.render('edit.html',{
student: student
})
})
});
router.post('/students/edit', function (req, res) {
Student.updateByIdAndUpdate(req.body, function(err){
if (err){
return res.status(500).send('Server err');
}
res.redirect('/students')
})
});
router.get('/students/delete', function(req, res) {
Student.findByIdAndRemove(req.query.id.replace(/"/g,''), function (err) {
if(err) {
return res.status(500).send('Server err');
}
res.redirect('/students')
})
});
//最后还要导出这个路由
module.exports = router;
router.js
mongodb方式实现数据库操作student1.js
//引入包
var mongoose = require('mongoose'); //连接数据库
mongoose.connect('mongodb://localhost/test'); //建立数据库架构
var Schema = mongoose.Schema; var studentSchema = new Schema({
name: {
type: String,
require: true
}, gender: {
type: Number,
enum: [0,1],
default: 0 }, age: {
type: Number
}
, hobbies: {
type: String
}
})
//导出
module.exports=mongoose.model('Student',studentSchema)
student1.js
2、通过mongodb可以很容易操作数据(不熟悉mongodb可以参考菜鸟教程)
第一步:先安装mongoose这个包,然后搭建数据库如下所示
//引入包
var mongoose = require('mongoose')
//连接数据库
mongoose.connect('mongodb://localhost/itcast', { useMongoClient: true }) var Schema = mongoose.Schema //设置数据库约束
var studentSchema = new Schema({
name: {
type: String,
required: true
},
gender: {
type: Number,
enum: [0, 1],
default: 0
},
age: {
type: Number
},
hobbies: {
type: String
}
}) // 直接导出模型构造函数
module.exports = mongoose.model('Student', studentSchema)
第二步:在router.js中引用
var fs = require('fs');
var express = require('express');
//加入student模块
var Student = require('./student1.js')
//express中转么提供了一种更好的方式可以用来包装路由
var router = express.Router();
//根据路径写好路由壳子
router.get('/students', function (req, res) {
//mongodb中直接用find方法来查找所有信息
Student.find(function (err, students) {
if(err) {
return res.status(500).send('Server err');
}
res.render('index.html', {
fruits: [
'苹果',
'香蕉',
'橘子'
],
students: students
})
})
});
router.get('/students/new', function (req, res){
res.render('new.html')
});
router.post('/students/new', function (req, res) {
console.log(req.body);
//mongodb中用save来保存,添加信息
var sudent = new Student(req.body)
sudent.save(function (err) {
if(err) {
return res.status(500).send('Server err');
}
res.redirect('/students')
})
});
//这一次通过get到那个编辑页面
router.get('/students/edit', function (req, res) {
//调用得到的是保存之后的数据
//1.如何获取数据
//2.处理数据
//3.发送响应
//4.将数据再次写入data.json文件
console.log(req.query.id);
//mongodb中直接用findById来查询具体的某条信息
Student.findById(req.query.id.replace(/"/g,''), function (err, student) {
if (err) {
return res.status(500).send('Server err');
}
//console.log(student);
res.render('edit.html',{
student: student
})
})
});
router.post('/students/edit', function (req, res) {
//mongdb中也可以根据如下来更新某一个信息
Student.updateByIdAndUpdate(req.body, function(err){
if (err){
return res.status(500).send('Server err');
}
res.redirect('/students')
})
});
router.get('/students/delete', function(req, res) {
//根据id删除具体的对象
Student.findByIdAndRemove(req.query.id.replace(/"/g,''), function (err) {
if(err) {
return res.status(500).send('Server err');
}
res.redirect('/students')
})
});
//最后还要导出这个路由
module.exports = router;
三、总结
node.js(小案例)_使用mongodb对学生信息列表优化的更多相关文章
- node.js(小案例)_实现学生信息增删改
一.前言 本节内容主要对小案例做一个总结: 1.如何开始搭建小项目 2.路由设计 3.模块应用 4.项目源码以及实现过程github地址: 项目演示如下: 二.主要内容 1.项目的关键性js源码: 项 ...
- node.js小案例_留言板
一.前言 通过这个案例复习: 1.node.js中模板引擎的使用 2.node.js中的页面跳转和重定向 二.主要内容 1.案列演示: 2.案列源码:https://github.com/45612 ...
- JS小案例--全选和全不选列表功能的实现
纯js代码实现列表全选和全不选的功能 <!DOCTYPE html> <html> <head lang="en"> <meta char ...
- JS小案例:循环间隔重复变色
在A.B.C三个区块中,有且仅有一个红色,要求红色每隔一秒即进入下一个区块,变色过程不断循环往复. 参考代码: <!DOCTYPE html> <html lang="zh ...
- KoaHub平台基于Node.js开发的Koa 连接支付宝插件代码信息详情
KoaHub平台基于Node.js开发的Koa 链接支付宝插件代码信息详情 easy-alipay alipay payment & notification APIs easy-alipay ...
- node.js(node.js+mongoose小案例)_实现简单的注册登录退出
一.前言 通过node.js基本知识对node.js基本知识的一个简单应用 1.注册 2.登录 3.退出 二.基本内容 1.项目结构搭建如图所示 2.这个小案列中用到了art-template子模板以 ...
- Node.js小项目——学生信息管理系统
这是迄今为止第一次接触后端的东西,是一个很小的项目,但是对于前端学习入门很好.我是先学了VUE框架再学的Node,学起来比较轻松,不过每个人都有自己的学习方法️ 一.项目描述 学生信息管理系统,可以实 ...
- Vue.js小案例、生命周期函数及axios的使用
一.调色框小案例: 随着三个滑动框的变化,颜色框的颜色随之改变 1.1.实例代码 <!DOCTYPE html> <html lang="en" xmlns:v- ...
- node.js小工具--修改Xcode 'Create by'作者名称
简介 用Xcode创建源文件时会自动在文件开始位置加入如下注释: // // ISSImageCycleScrollView.m // SoftTravel // // Created by iss1 ...
随机推荐
- Lodop打印维护PRINT_SETUP本地缓存ini文件
针对千差万别的客户端,Lodop提供了打印维护(PRINT_SETUP),可以针对某个客户端微调,调整结果保存在客户端本地,不会影响其他访问网站的用户的使用. 打印维护使用方法:1.PRINT_INI ...
- 工厂类,配置文件,静态方法,反射构成编译器解耦;ioc的一个概念 ;通过xml创建容器里面存储对象
工厂类,配置文件,静态,反射方法构成编译器解耦;ioc的一个概念
- 前端base64、baseurl加解密和RSA加解密
由于项目最近要进行安全测试,前端的用户和密码都是明文数据传送给后台那里,其实这样很很不安全的,容易泄露个人信息和密码.中间服务器的同事就提出,可以通过前端接收公钥,利用公钥对密码进行加密,把加密过密码 ...
- [BZOJ 2743] [HEOI 2012] 采花
Description 萧芸斓是Z国的公主,平时的一大爱好是采花.今天天气晴朗,阳光明媚,公主清晨便去了皇宫中新建的花园采花.花园足够大,容纳了 \(n\) 朵花,花有 \(c\) 种颜色(用整数 \ ...
- BZOJ2658 ZJOI2012 小蓝的好友(treap)
显然转化为求不包含关键点的矩形个数.考虑暴力,枚举矩形下边界,求出该行每个位置对应的最低障碍点高度,对其建笛卡尔树,答案即为Σhi*(slson+1)*(srson+1),即考虑跨过该位置的矩形个数. ...
- 微信小程序——安装开发工具和环境【二】
准备 开发工具下载 获取APPID 安装工具 安装 接受协议 选择安装位置 等待安装完成 安装完成 选择项目 选择小程序 填写信息 确定 无误后,点击确定进入开发页面 建立普通快速启动模板界面
- 查询SQLSERVER中系统表结构
Declare @TableName Varchar(20); SET @TableName='B_SupplierDA'; --SELECT TE.字段名+',' --FROM ( SELECT ( ...
- Hdoj 1159.Common Subsequence 题解
Problem Description A subsequence of a given sequence is the given sequence with some elements (poss ...
- 【CF809C】Find a car(动态规划)
[CF809C]Find a car(动态规划) 题面 洛谷 CF 有一个无穷大的矩阵,第\(i\)行第\(j\)列的数是\((i-1)xor(j-1)+1\),\(q\)次询问,每次询问一个矩形内数 ...
- 全局变量 static变量
变量 作用域 全局变量( external linkage ) 定义在函数外 Int a=1 作用于整个工程 在连接两个文件时若有两个a会报错 Staic 函数外(internal linkage) ...