NodeJS+Express+MongoDB 简单实现数据录入及回显展示【适合新人刚接触学习】
近期在看NodeJS相关
不得不说NodeJS+Express 进行网站开发是很不错,对于喜欢玩JS的来说真是很好的一种Web开发组合
在接触NodeJS时受平时Java或者C#中API接口等开发的思维惯性,类比着去学习了解发现其实很多都是通性的
特别是NodeJS中一个JS文件中方法通过exports可以在其他文件中进行require这种机制,不就类似Java中import(导入架包/引用类)?不就类似C#中Using(DLL组件或者引用类)么?
MVC模式下Web开发,其中对应在NodeJS中的路由(Router)不就是Controller? 其它M/V中想想都是一样,这样去一类比其实上手就赶脚一通百通
接下来就是些特定语言有特定的实现方式语法及特色
个人觉得在复杂的工程:其实前后端分离后,不就是后端怎么CRUD数据?前端怎么去使用接口回显数据对其交互等等;
工程的复杂性主要体现在业务逻辑实现/数据安全/Web性能/体验等等等吧
----扯多了-----------------------------------------------------
//在接触学习中,首先尝试了怎么去搭建工程连接数据库
下面就练手Test 做一个简单的Demo总结一下
适合新手刚开始接触的人
在Demo中主要是实现了怎么连接MongoDB数据库以及从数据库回显数据/还有往数据库中写入数据
//算是入门级的Demo走通了数据录入及回显
如下图:左侧展示录入的数据//右侧填写数据后点击OK 按钮数据就写入数据库
测试的录入的数据
//------------------------------------------------------------------------------------------------------------------------------------------------------------
首先环境安装啥的在理就不在赘述哈
创建Express 【Ejs模板的】工程 及Npm MongoDB 后 搭建对应文件夹【图中我的工程里面就加了一个Models】
关于其他文件夹百度上有很多对应说明介绍
//工程中我就采用默认路由 Index 【另外一个Users 我在程序入口 App.js中注释掉了(没啥业务含量用不上)】
首先是Models目录中
创建了个连接MongoDB数据库及构建数据
【上图中 TestDB.js 内容】
/**
* Created by Yi on 2017/5/8.
*/ //testDB Model //创建 mongodb数据库连接 var mongoose = require('mongoose');
var DB = mongoose.connect('mongodb://localhost:27017/testAppDB');//红色为数据库名 //
mongoose.connection.on("open", function () {
console.log("数据库连接成功");
}); //
mongoose.connection.on("error", function (error) {
console.log("数据库连接失败" + error);
});
//创建数据文档模板【在SQL数据库中 即一个表(列名字段等) NoSQL数据库中即数据文档(成员变量名)】
var testSchema = new mongoose.Schema({
SortID: {type: String},
Name: {type: String},
Sex: {type: String},
Address: {type: String},
timeDate: {type: Date, default: Date.now()}
}); module.exports = mongoose.model('TestModel', testSchema);
//下面在构造一个数据Model“类”
/**
* Created by Yi on 2017/5/8.
*/ // 上传/回显数据通用 数据Model
var tempModel = {
SortID: "",
Name: "",
Sex: "",
Address: "",
timeDate: ""
}; module.exports = tempModel;
Router【即 Controller 层】
var express = require('express');
var router = express.Router(); //引用连接数据库Model
var TestModel = require('../models/testDB'); // test 数据 // var resData = [];
// resData.push(
// {
// SortID: "1",
// Name: "A",
// Sex: "女",
// Address: "SSS",
// timeDate: "05-08"
// }
// );
// resData.push(
// {
// SortID: "2",
// Name: "B",
// Sex: "男",
// Address: "XXX",
// timeDate: "05-08"
// }
// ); // 初始化回显 数据库已录入数据
router.get('/', function (req, res, next) {
// res.render('testDB', {title: 'Express'});
TestModel.find({}, function (err, resData) {
if (err) return next(err);
res.render('index', {
title: "TestDB",
testData: resData
});
});
}); //1 可以直接用Form表单方式提交数据
//2 或者通过页面脚本绑定事件响应结合JQuery的Ajax
// 实现调用路由(controller)接口将数据写入数据库
//一般开发中会在页面脚本中调用很多其他或者外部接口//【该方式比较常用 即就把路由方法当成一个对外的接口】
router.post('/insert', function (req, res) {
var params = req.body;
//MogoDB中可以用Create方法添加数据
TestModel.create(params, function (err) {
if (err) res.end('{result:-1}');
else {
TestModel.find({}, function (error, data) {
if (error) res.end('{result:-1}');
else {
res.end('{result:1,data:' + data + '}');
}
});
}
});
});
module.exports = router;
View
我这直接在Index中修改页面【创建Express时采用的Ejs模板】当然用Html的也可以都是一样的
<!doctype html>
<html>
<head>
<meta charset="UTF-8">
<title><%= title %></title>
<link rel="stylesheet" href="/css/style.css">
</head>
<body> <div id="ShowDataArea">
<h4>此处展示 录入的数据 (用Ejs模板方式)</h4>
<span>多条数据采用forEach处理</span>
<% testData.forEach(function(testModel){ %>
<ul>
<li><span>编号</span><span><%= testModel.SortID %></span></li>
<li><span>姓名</span><span><%= testModel.Name %></span></li>
<li><span>性别</span><span><%= testModel.Sex %></span></li>
<li><span>地址</span><span><%= testModel.Address %></span></li>
</ul>
<% }) %> </div>
<div id="ShowArea">
<h4>采用 <%= title %> 测试Node - MongoDB 数据 写入/修改/删除/回显等</h4>
<hr>
<div id="SortID"><span>编号</span><input type="text" placeholder="编号"/></div>
<div id="Name"><span>姓名</span><input type="text" placeholder="姓名"/></div>
<div id="Sex"><span>性别</span><input type="text" placeholder="性别"/></div>
<div id="Address"><span>地址</span><input type="text" placeholder="地址"/></div>
<button id="uploadData">OK</button>
</div> </body>
<script type="text/javascript" src="/plug-in/jquery-1.9.1.js"></script>
<script type="text/javascript" src="/js/testPage.js"></script>
<!--页面JS如下-->
</html>
页面脚本:JS
var tempModel = {
SortID: "",
Name: "",
Sex: "",
Address: "",
timeDate: ""
}; $(function () {
$("#uploadData").on("click", function () {
alert("上传数据到MongoDB中");
//构造数据类
tempModel.SortID = $("#SortID").find("input").val();
tempModel.Name = $("#Name").find("input").val();
tempModel.Sex = $("#Sex").find("input").val();
tempModel.Address = $("#Address").find("input").val();
tempModel.timeDate = Date.now(); //通过Ajax更新数据
$.ajax({
type: 'post',
// url: "http://localhost:3000/insert",
url: "/insert",
dataType: "json",
data: tempModel,
success: function (resData) {
if (resData.result == 1) {
//更新页面列表
alert('resData');
}
},
error: function (error) {
alert('error:' + error);
}
});
});
});
//现在在回过来想想,结合常规MVC模式的Web开发去类比,这不就是一回事哈~~
//初版Demo
//后期NodeJS学习了解中会根据掌握,继续添加相应模块
NodeJS+Express+MongoDB 简单实现数据录入及回显展示【适合新人刚接触学习】的更多相关文章
- nodejs+express+mongodb简单的例子
简单的介绍下node+express+mongodb这三个东西.node:是运行在服务器端的程序语言,表面上看过去就是javascript一样的东西,但是呢,确实就是服务器语言,个人觉得在一定层次上比 ...
- NodeJS+Express+MongoDB 简单个人博客系统【Study笔记】
Blog 个人博客系统 iBlog是在学习NodeJs时候一个练手项目Demo 系统支持用户注册/登录,内容文章查看,评论,后台管理(定制显示的分类版块,进行文章内容添加)超级管理员还可进行用户管理等 ...
- NodeJS+Express+MongoDB
一.MongoDB MongoDB是开源,高性能的NoSQL数据库:支持索引.集群.复制和故障转移.各种语言的驱动程序丰富:高伸缩性:MongoDB 是一个基于分布式文件存储的数据库.由 C++ 语言 ...
- 【重点突破】—— Nodejs+Express+MongoDB的使用基础
前言:最近学习vue和react的高阶项目,都需要和Nodejs+Express+MongoDB结合实现全栈开发.这里结合实例Demo和所学项目集中总结一下这部分服务端的基础知识. 一.Express ...
- nodejs+express+mongodb实现登录注册
nodejs+express+mongodb实现登录注册 1 简介 登录注册功能使用nodejs+express+mongodb完成,其中对mongodb的操作使用mongoose完成,对mongod ...
- 从无到有,用Nodejs+express+mongodb搭建简易登陆系统
前端处理server表示很蛋疼,初学Node,虽然感觉异常强大,但是学起来还是有些吃力的,Node是工具,它不是万能的,搭建一个系统还是需要借助其他一些工具,对于我这个没怎么接触server的前端来说 ...
- NodeJs+Express实现简单的Web增删改查
前一段时间,公司组织了一次NodeJs的技术分享,自己有幸去听了听,第一次接触NodeJs,后来经过自己学习和探索,完成了一个很简单的Web演示项目,在这里和初学者做以分享,开发工具:WebStorm ...
- Nodejs&express+mongodb完成简单用户登录(即Nodejs入门)
刚了解nodejs,发现nodejs配置起来不复杂,但也有很多需要注意的地方,今天就记录一下,以后也可拿出来看看. 要完成这个简单的示例,从零开始,走三步就行了. 一.搭建开发环境 二.创建项目(ex ...
- nodejs+express+mongodb写api接口的简单尝试
1:启动mongodb服务 我的mongoDB的安装目录:E:\mongoDB\bin,版本:3.4.9 打开cmd -> e:(进入e盘) -> cd mongoDB/bin(进入mo ...
随机推荐
- JDBC连接数据以及操作数据
好久没有写博文了,写个简单的东西热热身,分享给大家. jdbc相信大家都不陌生,只要是个搞java的,最初接触j2ee的时候都是要学习这么个东西的,谁叫程序得和数据库打交道呢!而jdbc就是和数据库打 ...
- centos6.7编译安装mysql5.7.17
centos6.7编译安装mysql5.7.17 2017-03-24 09:57:15 提示:mysql5.7.17和之前5.56以前的版本安装不一样,需要用cmake 另外,看本文档的mysql编 ...
- windows系统下安装composer
使用安装程序安装 这是将 Composer 安装在你机器上的最简单的方法. 下载并且运行 Composer-Setup.exe,它将安装最新版本的 Composer 安装完成后,将composer的b ...
- java学习笔记----运算符
一.算数运算符 特别说明: 加 ,减 ,乘 ,除 与数学运算一致 取余符号看被除数 自加(减)运算:++a,--a;先做自加(自减)运算在做其他运算 a++,a--;先做其他运算在做自加(自减)运算 ...
- 基于均值漂移的三维网格分割算法(Mean Shift)
mean shift算法是一种强大的无参数离散数据点的聚类方法,其在图像平滑.图像分割以及目标跟踪等方面都有着广泛的应用.[Yamauchi et al. 2005]基于mean shift算法提出了 ...
- PRINCE2的价值是什么?
很多学员在进行培训的过程中或者培训后,都会对于PRINCE2带来的价值有各种各样的看法.但是从更加官方一点的角度来说,PRINCE2会有一部分比较通用 的观点. PRINCE2 可以应用到任何类型的项 ...
- 【Egret】WebSocket 的使用说明
在Egret里可以使用WebSocket ,也可以使用socket.io 首先先深入了解一下 WebSocket 在Egret里的机制,看这篇文章: 主要讲解Egret里使用WebSocket和pro ...
- Java基础之J2EE规范
什么是J2EE? 在企业级应用中,都有一些通用企业需求模块,如数据库连接,邮件服务,事务处理等.既然很多企业级应用都需要这些模块,一些大公司便开发了自己的通用模块服务,即中间件.这样一来,就避免了重复 ...
- 老李教你性能测试监控工具nmon
老李教你性能测试监控工具nmon loadrunner的某些性能监控器不够强大,这就需要我们利用更好的工具进行监控,在项目中我们会用nmon工具作为辅助性能监控的工具,帮助我们进行性能分析,pop ...
- Visual Studio 2017无法加载Visual Studio 2015创建的SharePoint解决方案
前几天安装了最新的Visual Studio 2017企业版,发现无法打开之前使用Visual Studio 2015创建的SharePoint 2016解决方案,提示"需要更新" ...