node.js+express+mongodb对用户进行增删查改

一、用到的相关技术

  1. 使用 Node.js 的 express 框架搭建web服务
  2. 使用 express 中间件 body-parse 解析表单 post 请求体
  3. 使用 art-template 模板引擎渲染页面
  4. 使用第三方包 mongoose 来操作 MongoDB 数据库

二、在命令行用 npm 执行相关的命令

  1. 初始化项目,在命令行执行 npm init 然后一路回车就行了(或者直接 npm init -y)生成 package.json 文件,它相当于是你项目的说明书
npm init
  1. 安装需要用到的各种包
# Express 框架
npm install express # 模板引擎(express-art-template 是模板引擎与 express 的关联包)
npm install art-template express-art-template # express 中间件 body-parser
npm install body-parser # mongoose
npm install mongoose

三、项目结构说明

四、路由设计

请求方法 请求路径 get 参数 post 参数 备注
GET /user 渲染首页
GET /add 渲染添加用户页面
POST /add name、age、gender、job、hobbies 处理添加用户请求
GET /edit id 渲染编辑页面
POST /edit id、name、age、gender、job、hobbies 处理编辑请求
GET /delete id 处理删除请求

五、编写代码

  1. 入口模块: app.js

    /**
    * app.js 服务入口模块
    * 1. 创建服务
    * 2. 做服务相关的配置
    * 2.1 模板引擎
    * 2.2 body-parser 解析表单 post 请求体
    * 2.3 提供相关的静态资源服务(开放public目录)
    * 3. 挂载路由
    * 4. 监听端口 开启服务
    * */ var express = require('express')
    var router = require('./router.js')
    var bodyParser = require('body-parser') //创建你的服务器应用程序
    var app = express() //指定 .html 后缀的文件使用的解析引擎
    app.engine('html',require('express-art-template')) //开发静态资源
    app.use('/public/',express.static('./public/'))
    app.use('/node_modules/',express.static('./node_modules/')) // 配置 body-parser 中间件(插件,专门用来解析表单 POST 请求体)
    // parse application/x-www-form-urlencoded
    app.use(bodyParser.urlencoded({ extended: false }))
    // parse application/json
    app.use(bodyParser.json()) //把路由挂载到 app 服务中
    app.use(router) //开启服务
    app.listen(3000,function(){
    console.log('server is running ...')
    })
  2. 路由模块: router.js

    /**
    *
    * router.js 路由模块
    * 根据不同的请求方法 + 请求路径 设置具体的请求处理函数
    *
    * */ var express = require('express')
    var User = require('./user.js') //1. 创建一个路由
    var router = express.Router() //2. 把路由都挂载到 router 路由容器中 // =============渲染用户列表页面=============
    router.get('/users',function(req,res){
    User.find(function(err,users){
    if(err){
    return res.status(500).send('Server err')
    }
    res.render('index.html',{users:users})
    })
    }) // =============渲染添加用户信息页面===========
    router.get('/add',function(req,res){
    res.render('add.html')
    }) // ==============处理添加用户==================
    router.post('/add',function(req,res){
    //1. 获取表单数据 req.body
    //2. 处理:将数据保存到 db.json 文件中用以持久化
    new User(req.body).save(function(err){
    if(err){
    return res.status(500).send('server err')
    }
    //3. 重定向到首页
    res.redirect('/users')
    })
    }) // =================渲染编辑用户信息页面============
    router.get('/edit',function(req,res){
    //1. 在客户端的列表中处理链接问题(需要有 id 参数)
    //获取要编辑的学生 通过id
    User.findById(req.query.id.replace(/"/g,''),function(err,user){
    if(err){
    return res.status(500).send('Server error')
    }
    res.render('edit.html',{
    user:user
    })
    })
    }) // ==================处理编辑用户信息================
    router.post('/edit',function(req,res){
    //1. 获取表单数据 req.body
    //2. 通过 id 更新 User.findByIdAndUpdate()
    //3. 重定向到首页
    User.findByIdAndUpdate(req.body.id.replace(/"/g,''),req.body,function(err){
    if(err){
    return res.status(500).send('server error')
    }
    res.redirect('/users')
    })
    }) // ==================删除用户====================
    router.get('/delete',function(req,res){
    // 通过 id 查找到对应用户进行删除 User.findByIdAndDelete()
    User.findByIdAndRemove(req.query.id.replace(/"/g,''),function(err){
    if(err){
    return res.status(500).send('server error')
    } })
    res.redirect('/users') }) // 把路由导出
    module.exports = router
  3. 创建数据库 model 模块: user.js

    var mongoose = require('mongoose')
    
    //连接数据库 数据库名(usersdb) 没有会自动创建
    mongoose.connect('mongodb://localhost/usersdb') //定义数据库表结构 schema
    var Schema = mongoose.Schema //设计表结构
    var userSchema = new Schema({
    name:{
    type:String,
    require:true
    },
    gender:{
    type:Number,
    enum:[0,1],
    default: 0
    },
    age:{
    type:Number
    },
    job:{
    type:String
    },
    hobbies:{
    type:String
    }
    }) //将文档结构发布为模型并导出
    module.exports = mongoose.model('User',userSchema)
    1. 视图模块

      4.1 index.html

      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title>index</title>
      <link rel="stylesheet" href="/public/css/css.css">
      <link rel="stylesheet" href="/public/css/index.css">
      </head>
      <body>
      <header>
      <div class="left"> 用户管理系统</div>
      <div class="right"> 欢迎登陆 admin | 退出</div>
      </header>
      <div class="slide">
      <ul>
      <li>用户信息</li>
      </ul>
      </div>
      <div class="add">
      <a href="/add">添加用户</a>
      </div>
      <div class="content">
      <table cellspacing="0">
      <thead>
      <tr>
      <td>姓名</td>
      <td>性别</td>
      <td>年龄</td>
      <td>爱好</td>
      <td>职位</td>
      <td>操作</td>
      </tr>
      </thead>
      <tbody>
      {{ each users }}
      <tr>
      <td>{{ $value.name }}</td>
      {{if $value.gender==0 }}
      <td>男</td>
      {{ else }}
      <td>女</td>
      {{ /if }}
      <td>{{ $value.age }}</td>
      <td>{{ $value.hobbies }}</td>
      <td>{{ $value.job }}</td>
      <td>
      <!-- 注意这里 id={{ }} 的=(这个等号)前后不能打空格 不能打成 id = {{ }}
      因为打了空格就相当于加了字符串空格,获取的id会有误 -->
      <a href="/edit?id={{ $value._id }}">编辑</a>
      <a href="/delete?id={{ $value._id }}">删除</a>
      </td>
      </tr>
      {{ /each }}
      </tbody>
      </table>
      </div>
      </body>
      </html>

      4.2 add.html

      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title>index</title>
      <link rel="stylesheet" href="/public/css/css.css">
      <link rel="stylesheet" href="/public/css/form.css">
      </head>
      <body>
      <header>
      <div class="left"> 用户管理系统</div>
      <div class="right"> 欢迎登陆 admin | 退出</div>
      </header>
      <div class="slide">
      <ul>
      <li>用户信息</li>
      </ul>
      </div>
      <div class="content">
      <div class="box">
      <div class="top">添加信息</div>
      <form action="/add" method="post">
      <table>
      <tr>
      <td>姓名:</td>
      <td><input type="text" name="name" class="text" placeholder="请输入用户名"></td>
      </tr>
      <tr>
      <td>性别:</td>
      <td>
      男:<input type="radio" name="gender" value="0">
      女:<input type="radio" name="gender" value="1">
      </td>
      </tr>
      <tr>
      <td>年龄:</td>
      <td><input type="number" name="age" class="text"></td>
      </tr>
      <tr>
      <td>爱好:</td>
      <td><input type="text" name="hobbies" class="text"></td>
      </tr>
      <tr>
      <td>职位:</td>
      <td><input type="text" name="job" class="text"></td>
      </tr>
      <tr>
      <td colspan="2">
      <input type="submit" value="提交" class="button">
      <input type="reset" value="重置" class="button">
      </td>
      </tr>
      </table>
      </form>
      </div>
      </div>
      </body>
      </html>

      4.3 edit.html

      <!DOCTYPE html>
      <html lang="en">
      <head>
      <meta charset="UTF-8">
      <title>index</title>
      <link rel="stylesheet" href="/public/css/css.css">
      <link rel="stylesheet" href="/public/css/form.css">
      </head>
      <body>
      <header>
      <div class="left"> 用户管理系统</div>
      <div class="right"> 欢迎登陆 admin | 退出</div>
      </header>
      <div class="slide">
      <ul>
      <li>用户信息</li>
      </ul>
      </div>
      <div class="content">
      <div class="box">
      <div class="top">添加信息</div>
      <form action="/edit" method="post">
      <!--
      用来放一些不希望被用户看见,但是需要被提交到服务端的数据
      -->
      <input type="hidden" name="id" value="{{ user.id }}">
      <table>
      <tr>
      <td>姓名:</td>
      <td><input type="text" class="text" name="name" value="{{ user.name }}"></td>
      </tr>
      <tr>
      <td>性别:</td>
      <td>
      {{ if user.gender == 0 }}
      男:<input type="radio" name="gender" value="0" checked>
      女:<input type="radio" name="gender" value="1">
      {{ else }}
      男:<input type="radio" name="gender" value="0" >
      女:<input type="radio" name="gender" value="1" checked>
      {{ /if }}
      </td>
      </tr>
      <tr>
      <td>年龄:</td>
      <td><input type="number" class="text" name="age" value="{{ user.age }}"></td>
      </tr>
      <tr>
      <td>爱好:</td>
      <td><input type="text" class="text" name="hobbies" value="{{ user.hobbies }}"></td>
      </tr>
      <tr>
      <td>职位:</td>
      <td><input type="text" class="text" name="job" value="{{ user.job }}"></td>
      </tr>
      <tr>
      <td colspan="2">
      <input type="submit" value="提交" class="button">
      <input type="reset" value="重置" class="button">
      </td>
      </tr>
      </table>
      </form>
      </div>
      </div>
      </body>
      </html>

六、测试

  1. 连接数据库

    mongod
  2. 开启服务

    nodemon app.js
  3. 运行结果

项目下载地址:https://github.com/zyxWebGitHub/Node.git

node.js+express+mongoose实现用户增删查改案例的更多相关文章

  1. [node.js]express+mongoose+mongodb的开发笔记

    时间过得很快,6月和7月忙的不可开交,糟心的事儿也是不少,杭州大连来回飞,也是呵呵. 希望下个阶段能沉浸下来,接着学自己想学的.记一下上几周用了几天时间写的课设.因为课设的缘故,所以在短时间里了解下e ...

  2. js实现对数据库的增删查改

    1.查询 复制代码 代码如下: <HTML> <HEAD> <TITLE>数据查询</TITLE> <Script > var conn = ...

  3. 博客系统实战——SprintBoot 集成Thymeleaf 实现用户增删查改(含源码)

    近来在学习SprintBoot +Thymeleaf +Maven搭建自己的博客系统,故在学习过程中在此记录一下,也希望能给广大正在学习SprintBoot和Thymeleaf的朋友们一个参考. 以下 ...

  4. SpringBoot整合Mybatis-plus实现增删查改

    今天给大家分享一下SpringBoot整合Mybatis-plus的增删查改案例. pom.xml <?xml version="1.0" encoding="UT ...

  5. node.js+mysql增删查改

    数据库和表: -- -- 数据库: `test` -- -- -------------------------------------------------------- -- -- 表的结构 ` ...

  6. Node.js Express+Mongodb 项目实战

    Node.js Express+Mongodb 项目实战 这是一个简单的商品管理系统的小项目,包含的功能还算挺全的,项目涵盖了登录.注册,图片上传以及对商品进行增.删.查.改等操作,对于新手来说是个很 ...

  7. modeJS 深了解(1): Node.js + Express 构建网站预备知识

    转载:http://www.cnblogs.com/zhongweiv/p/nodejs_express_webapp1.html 目录 前言 新建express项目并自定义路由规则 如何提取页面中的 ...

  8. Node.js+Express+MongoDB数据库实现网页注册登入功能

    通过 Node.js + Express + MongoDB 实现网页注册账号 和 登入账号的功能 项目准备: 1: 事先准备好项目的页面 (首页页面 index.html)(登入页面 login.h ...

  9. Node.js Express 框架学习

    转载:http://JavaScript.ruanyifeng.com/nodejs/express.html#toc0 感觉很牛的样子,不过觉得对初学者没太大用,里面很多例子用的api都没有详细的说 ...

随机推荐

  1. 关于Element对话框组件Dialog在使用时的一些问题及解决办法

    Element对话框组件Dialog在我们的实际项目开发中可以说是一个使用频率较高的组件,它能为我们展示提示的功能,如:业务模块提交前展示我们曾经输入或选择过的业务信息,或者展示列表信息中某项业务的具 ...

  2. 数字金字塔 动态规划(优化版) USACO 一维dp压缩版

    1016: 1.5.1 Number Triangles 数字金字塔 时间限制: 1 Sec  内存限制: 128 MB提交: 9  解决: 8[提交] [状态] [讨论版] [命题人:外部导入] 题 ...

  3. ORM基础3 在python脚本里调用Django环境

    1.查询 1.# all获取所有的object,结果QuerySet,列表 print('all'.center(80, '=')) ret = models.Person.objects.all() ...

  4. 9.Java三大版本以及JDK,JRE,JVM简单介绍

    Write Once,Run Anywhere. JavaSE:标准版(桌面程序,控制台开发...),是Java的基础和核心. JavaME:嵌入式开发(手机,小家电...),现在基本不用已经过时. ...

  5. Java入门 - 导读

    原文地址:http://www.work100.net/training/java 更多教程:光束云 - 免费课程 Java入门 Java 是由 Sun Microsystems 公司于1995年5月 ...

  6. OA系统、ERP系统、CRM系统的区别和联系有哪些?企业该如何使用?

    我们经常听到很多企业会花重金购买适合企业的ERP.OA和CRM系统,使得公司的管理运营更加高效有序,节省公司运营成本,带来更大的经济效益,但实际上很多人员都不太理解他们之间的区别和联系是什么,到底该如 ...

  7. spring整合Mybati时,只报空指针异常问题

    异常如下: 在整合spring和Mybatis,刚开始进行查询映射时没有问题,在进行插入映射时一直报空指针异常,后来把插入部分的Mapper映射文件和Dao层接口方法删除到原来还是不行,后来网上查了查 ...

  8. 「 从0到1学习微服务SpringCloud 」07 RabbitMq的基本使用

    系列文章(更新ing): 「 从0到1学习微服务SpringCloud 」01 一起来学呀! 「 从0到1学习微服务SpringCloud 」02 Eureka服务注册与发现 「 从0到1学习微服务S ...

  9. 批量解决win10图标上有两个蓝色箭头的方法

    双击“此电脑”,点击“C盘”,可以看到一个”用户“文件夹,双击”用户“, 选择现在正在使用的用户名,双击用户名,找到该文件夹下的”桌面“或”Desktop“点击“属性”, 在“常规”选项卡中的属于项中 ...

  10. 龙芯 3B1500 Fedora28 安装笔记

    版权声明:原创文章,未经博主允许不得转载 龙芯 3A4000 已经发布,十年前的 3B1500 早就落伍了.但我还是打算把它作为寒假刷 ACM 题的主力机 并将此当作年后收到 4000 的预习. 龙芯 ...