http://www.cnblogs.com/flyoung2008/archive/2012/07/22/2603791.html
nodejs学得异常痛苦,在这里将学的东西做一番整理,算是自我安慰吧。根据网上todo示例,用express和mongoose重写了部分代码,主要是业务逻辑这块(CRUD),这个没什么难度。目前尚未解决的问题是:express不能使用ejs
layout template,查了好久也没解决,知道的麻烦告诉我一下。
一、代码目录
二、第三方模块
1、express
(1)express中文入门指引手册
(2)nodejs中文电子书
(3)如何在WebStorm中建立express工程?
安装express
安装成功后在node_modules下会找到express目录,同时也会找到.bin目录,它里面有express命令脚本
在终端下执行
project_name为实际的nodejs工程名/路径 比如笔者:E:/Nodejs/todo
(4)Express官方文档
2、ejs
EJS快速入门教程
3、mongoose
mongoose2.7.0文档
Mongoose-让NodeJS更容易操作Mongodb数据库
三、核心介绍
1、使用mongoose写的dao(CRUD)
var util = require('util');
var mongoose = require('mongoose');
var Schema = mongoose.Schema;
var dburl = require("../config").db;//数据库地址
exports.connect = function(callback) {
mongoose.connect(dburl);
}
exports.disconnect = function(callback) {
mongoose.disconnect(callback);
}
exports.setup = function(callback) { callback(null); }
//定义todo对象模型
var TodoScheme = new Schema({
title:String
,finished:{type:Boolean,default:false}
,post_date:{type:Date,default:Date.now}
});
//访问todo对象模型
mongoose.model('Todo', TodoScheme);
var Todo = mongoose.model('Todo');
//exports.emptyNote = { "_id": "", author: "", note: "" };
exports.add = function(title,callback) {
var newTodo = new Todo();
newTodo.title = title;
newTodo.save(function(err){
if(err){
util.log("FATAL"+err);
callback(err);
}else{
callback(null);
}
});
}
exports.delete = function(id, callback) {
exports.findTodoById(id, function(err, doc) {
if (err)
callback(err);
else {
util.log(util.inspect(doc));
doc.remove();
callback(null);
}
});
}
exports.editTitle = function(id, title, callback) {
exports.findTodoById(id, function(err, doc) {
if (err)
callback(err);
else {
doc.post_date = new Date();
doc.title = title;
doc.save(function(err) {
if (err) {
util.log('FATAL '+ err);
callback(err);
} else
callback(null);
});
}
});
}
exports.editFinished = function(id, finished, callback) {
exports.findTodoById(id, function(err, doc) {
if (err)
callback(err);
else {
doc.post_date = new Date();
doc.finished = finished;
doc.save(function(err) {
if (err) {
util.log('FATAL '+ err);
callback(err);
} else
callback(null);
});
}
});
}
exports.allTodos = function(callback) {
Todo.find({}, callback);
}
exports.forAll = function(doEach, done) {
Todo.find({}, function(err, docs) {
if (err) {
util.log('FATAL '+ err);
done(err, null);
}
docs.forEach(function(doc) {
doEach(null, doc);
});
done(null);
});
}
var findTodoById = exports.findTodoById = function(id,callback){
Todo.findOne({_id:id},function(err,doc){
if (err) {
util.log('FATAL '+ err);
callback(err, null);
}
callback(null, doc);
});
}
2、url路由控制
"use strict";
var config = require('../config');
var db = require('../dao/todoDao');
exports.index = function (req, res, next) {
db.allTodos(function (err, todos) {
if (err) {
return next(err);
}
res.render('index.html', {todos: todos});
});
};
exports.new = function (req, res, next) {
var title = req.body.title || '';
title = title.trim();
if (!title) {
return res.render('error.html', {message: '标题是必须的'});
}
db.add(title, function (err, row) {
if (err) {
return next(err);
}
res.redirect('/');
});
};
exports.view = function (req, res, next) {
res.redirect('/');
};
exports.edit = function (req, res, next) {
var id = req.params.id;
db.findTodoById(id, function (err, row) {
if (err) {
return next(err);
}
if (!row) {
return next();
}
res.render('todo/edit.html', {todo: row});
});
};
exports.save = function (req, res, next) {
var id = req.params.id;
var title = req.body.title || '';
title = title.trim();
if (!title) {
return res.render('error.html', {message: '标题是必须的'});
}
db.editTitle(id,title,function (err, result) {
if (err) {
return next(err);
}
res.redirect('/');
});
};
exports.delete = function (req, res, next) {
var id = req.params.id;
db.delete(id, function (err) {
if (err) {
return next(err);
}
res.redirect('/');
});
};
exports.finish = function (req, res, next) {
var finished = req.query.status === 'yes' ? true : false;
var id = req.params.id;
db.editFinished(id,finished, function (err, result) {
if (err) {
return next(err);
}
res.redirect('/');
});
};
3、使用express框架
var express = require('express')
, todo = require('./controllers/todo')
, http = require('http')
, config = require("./config")
, todoDao = require("./dao/todoDao");
var app = express();
app.engine('html', require('ejs').renderFile);
app.configure(function(){
app.set('port', config.port);
app.set('view engine', 'ejs');
app.set('views', __dirname + '/views');
app.use(express.logger('dev'));
app.use(express.bodyParser());
app.use(express.methodOverride());
app.use(app.router);
app.use(express.static(__dirname + '/public'));
});
app.configure('development', function(){
app.use(express.errorHandler());
});
//url路由
app.get('/', todo.index);
app.post('/todo/new', todo.new);
app.get('/todo/:id', todo.view);
app.get('/todo/:id/edit', todo.edit);
app.post('/todo/:id/edit', todo.save);
app.get('/todo/:id/delete', todo.delete);
app.get('/todo/:id/finish', todo.finish);
todoDao.connect(function(error){
if (error) throw error;
});
app.on('close', function(errno) {
todoDao.disconnect(function(err) { });
});
http.createServer(app).listen(app.get('port'), function(){
console.log("Express server listening on port " + app.get('port'));
});
注意点:为了在ejs中能使用.html,以下这句是关键,app.register()不能用了
app.engine('html', require('ejs').renderFile);
困惑点:如何在express中使用ejs的layout模板,具体是怎么设置的?!知道的麻烦说一下,谢谢~~~
四、源码
程序员不是求源码,就是求无码。
todo源码
分享到:
相关推荐
nodejs + express + mongoose demo and documents
这是一个vue+nodejs+express+mybatis够成的一个项目案例
本文主要介绍NodeJS+Express+Mysql 实现POST和GET请求的增删改查,后续会在博客发布详细说明,可以关注一下
自己电脑需要安装mongodb数据库 和mongoose ,自己在用的时候,记得要和对应数据库和表名一致
nodejs+Express+mssql,SQL Server实现增删改查
>本文主要介绍NodeJS+Express+Mysql实现用户登录和注册。此登录注册的方式为get
基于vue2+Mysql+nodejs+express+element-ui的前后端分离图书管理系统 使用步骤: 本地运行方法  1.新建一个名为books_manage_system的数据库  2.将node目录下books_manage_system.sql文件导入到该数据库...
nodejs + express + ejs + mongodb 一个非常简单的前后端开发的实例
基于Nodejs+Express+Mongodb的记账本后端系统源码(课程设计).zip基于Nodejs+Express+Mongodb的记账本后端系统源码(课程设计).zip基于Nodejs+Express+Mongodb的记账本后端系统源码(课程设计).zip基于Nodejs+Express+...
基于NodeJS+Express+mongoDB+Bootstrap的全栈式工程化开发前后端分离博客系统实战
图书管理系统,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+mongodb+mongoose,搭建一个个人博客系统
管理系统系列--Nodejs + Express + Ejs + Mysql 后台管理系统
webstorm10环境下开发的nodejs项目,采用node.js+express4+mongoose+ejs,所有api均为2015年6月最新版本,如果你被网上的诸如nodejs开发指南坑了,那么参照我的源码,包含一篇个人总结的nodejs开发步骤以及常见问题...
nodejs+express入门小例子,掌握nodejs+express的模块化开发以及基本属性
毕业设计,基于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