关闭

Node学习笔记:优化crud增删改查

时间: 2019-12-16阅读: 564标签: 优化

本篇文章结合前文《Node学习笔记 Mongodb和Mongoose》对 curd 示例 进行优化


MongoDB 安装

安装文件下载地址:[https://www.mongodb.com/download-center/community]

Windows 平台安装 MongoDB:https://www.runoob.com/mongodb/mongodb-window-install.html

在安装过程中需要特别注意,需要将 Install MongoDB Compass 前默认的勾选取消

可以使用 mongod --version 命令查看 MongoDB 版本,若版本号输出正常则安装完毕


Mongoose 安装和配置

npm install mongoose


优化 student.js 文件

有了 Mongoose 的帮助可以极大的简化数据的增、删、改、查工作

首先,配置 Mongoose

var mongoose = require('mongoose'); // 引入 mongoose
mongoose.connect('mongodb://localhost/test'); // 通过 mongoose 连接 mongodb 数据

其次,设计 Schema 数据结构

var mongoose = require('mongoose'); // 引入 mongoose
mongoose.connect('mongodb://localhost/test'); // 通过 mongoose 连接 mongodb 数据库

// 设计数据结构
var Schema = mongoose.Schema
var studentData = new Schema({ // 实例化 Schema
    name: { // 姓名
        type: String, // 数据类型 String
        required: true // 数据为必填项
    },
    gender: { // 性别
        type: Number, // 数据类型 Number
        default: 0, // 数据默认值
        enum: [0, 1] // 可枚举数据
    },
    age: { // 年龄
        type: Number // 数据类型 Number
    },
})

最后,导出 Student

module.exports= mongoose.model('Student', studentData)
// 将数据保存 Mongodb 数据库 Student 集合中
// 导出 Mongodb 数据

到此为止,student.js 优化完毕


优化 router.js 文件

对于 router.js 文件,我们只需要调用 mongoose 提供的增、删、改、查 API 既可

代码如下:

var Student = require('./student') // 引入 student.js (student 模块专职用于处理数据)

var express = require('express') // 引入 express
var router = express.Router() // 创建路由容器

// 将所有路由都挂在到 router 路由容器中
router.get('/', function (req, res) { // 渲染学生列表页面
	// .find() 用于从数据库中查询所有数据,接收一个函数参数
    // function (err, students) 接收两个参数,其一为错误信息,二为查询的数据 students
    Student.find(function (err, students) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.render('index.html', { // 响应返回学生列表页面
            students: students
        })
    })
})

router.get('/new', function (req, res) { // 渲染添加学生页面
    res.render('new.html')
})

router.post('/new', function (req, res) { // 处理添加学生
    // new Student(req.body) 新建一条数据
    // .save 用于将数据添加到数据库,接收一个函数参数
    // function (err) 参数用于接收错误信息
    new Student(req.body).save(function (err) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.redirect('/') // 页面重定向回首页
    })
})

router.get('/edit', function (req, res) { // 渲染编辑学生页面
    // .findById() 用于根据 id 查询一条数据,接收两个参数,其一为匹配数据,二为函数
    // function (err, student) 函数接收两个参数,其一为错误信息,二为查询数据结果
    // req.query.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型
    Student.findById(req.query.id.replace(/"/g, ''), function (err, student) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.render('edit.html', { // 响应返回编辑学生页面
            student: student
        })
    })
})

router.post('/edit', function (req, res) { // 处理编辑学生
    // .findByIdAndUpdate() 用于根据 id 更新数据,接收三个参数,其一为匹配数据,二为需替换的数据,三为函数
    // function (err) 函数接收错误信息
    // req.body.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型
    var id = req.body.id.replace(/"/g, '')
    Student.findByIdAndUpdate(id, req.body, function (err) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.redirect('/') // 页面重定向回首页
    })
})

router.get('/students/delete', function (req, res) { // 处理删除学生
    // .findByIdAndRemove() 用于根据 id 删除对应数据,接收两个参数,其一为匹配数据,二为函数
    // function (err) 函数接收错误信息
    // req.body.id.replace(/"/g, '') 为需查询的数据 id ,通过 .replace 将 id 字符串转化为数字类型
    var id = req.query.id.replace(/"/g, '')
    Student.findByIdAndRemove(id, function (err) {
        if (err) { // 若路由跳转错误,则抛出 Server error,状态码 500
            return res.status(500).send('Server error.')
        }
        res.redirect('/') // 页面重定向回首页
    })
})

module.exports = router // 导出 router

文章已同步我的个人博客:《Node学习笔记 优化crud增删改查

站长推荐

1.云服务推荐: 国内主流云服务商,各类云产品的最新活动,优惠券领取。地址:阿里云腾讯云华为云

2.广告联盟: 整理了目前主流的广告联盟平台,如果你有流量,可以作为参考选择适合你的平台点击进入

链接: http://www.fly63.com/article/detial/6875

关闭

​web项目优化_Web 服务器性能与站点访问性能优化

要优化 Web 服务器的性能,我们先来看看 Web 服务器在 web 页面处理上的步骤:Web 浏览器向一个特定的服务器发出 Web 页面请求; Web 服务器接收到 web 页面请求后,寻找所请求的 web 页面,并将所请求的 Web 页面传送给 Web 浏览器; 显示出来

一次Web端大量图片同时加载卡顿问题的优化之旅

由于业务的需要,笔者最近需要实现一个大量图片同时加载的需求。在实现这个需求的过程中,笔者遇到了很多的坑,也总结了一些优化方案。这里将笔者使用或准备使用的优化方案总结一下。

web系统整体优化提速总结

随着公司业务的拓展,随之而来就是各种系统横向和纵向的增加,PV、UV也都随之增加,原有的系统架构和模式慢慢遇上了瓶颈,需要逐步的对系统从整体上进行改造升级,通过一段时间的整理思路

网站打开速度优化_如何提高网页访问速度技巧方法总结

网站的加载速度不仅影响着用户体验,也会影响搜索引擎的排名,在百度推出“闪电算法”以来,将网站首屏打开速度被列入优化排名行列,作为前端开发的我们需要如果来优化网站的打开速度呢?下面就整理挖掘出很多细节上可以提升性能的东西分享给大家

我是如何将页面加载时间从6S降到2S的?

生活在信息爆炸的今天,我们每天不得不面对和过滤海量的信息--无疑是焦躁和浮动的,这就意味着用户对你站点投入的时间可能是及其吝啬的(当然有一些刚需站点除外)。如何给用户提供迅速的响应就显得十分重要了

移动 H5 首屏加速、优化方案

随着移动设备性能不断增强,web 页面的性能体验逐渐变得可以接受,又因为 web 开发模式的诸多好处(跨平台,动态更新,减体积,无限扩展)

js前端性能优化之函数节流和函数防抖

针对一些会频繁触发的事件如scroll、resize,如果正常绑定事件处理函数的话,有可能在很短的时间内多次连续触发事件,十分影响性能。节流:使得一定时间内只触发一次函数。 防抖动:将几次操作合并为一此操作进行。

从浏览器内部运行机制看性能优化

获取到的HTML/CSS/JS资源经过浏览器内核的处理生成图像呈现在浏览器上,那么下面我们就详细说说浏览器内核在拿到资源之后是经过哪些处理来生成我们最终所看到的页面。

优化(Vue)Javascript文件体积

可以看到竟然有8M和5.3M这么大的文件!在本地开发时由于本地网络打开文件很快感受不明显,但当把这些文件部署到服务器上,能明显感觉首屏打开时间是非常慢的。好,看到了问题,我们来优化~

网站性能优化实战

读取缓存→DNS查询→TCP链接→发起请求→接收响应→处理HTML元素→加载完成。CSS属性读写分离:浏览器每次对元素样式进行读操作时,都必须进行一次重新渲染(重排 + 重绘)

点击更多...

内容以共享、参考、研究为目的,不存在任何商业目的。其版权属原作者所有,如有侵权或违规,请与小编联系!情况属实本人将予以删除!