nodejs学得异常痛苦,在这里将学的东西做一番整理,算是自我安慰吧。根据网上todo示例,用express和mongoose重写了部分代码,主要是业务逻辑这块(CRUD),这个没什么难度。目前尚未解决的问题是:express不能使用ejs layout template,查了好久也没解决,知道的麻烦告诉我一下。

一、代码目录

二、第三方模块

1、express

(1)express中文入门指引手册

(2)nodejs中文电子书

(3)如何在WebStorm中建立express工程?

安装express

npm install express

安装成功后在node_modules下会找到express目录,同时也会找到.bin目录,它里面有express命令脚本

在终端下执行

express project_name

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+ejs+mongoose实例的更多相关文章

  1. 用nodejs,express,ejs,mongo,extjs实现了简单了网站后台管理系统

    源代码下载地址:http://download.csdn.net/detail/guoyongrong/6498611 这个系统其实是出于学习nodejs的目的而改写的系统. 原来的系统前端使用了ex ...

  2. Windows环境下,从零开始搭建Nodejs+Express+Ejs框架(二)---安装Express,ejs

    安装Express,ejs的前提是一定要先安装nodejs,具体安装方法请查看 http://www.cnblogs.com/tfiremeteor/p/8973105.html 安装Express和 ...

  3. Nodejs + express + ejs

    特性 <% %> 用于控制流 <%= %> 用于转义的输出 (会对数据字符进行转义) // 数据源 // app.js var tem={ title:"我是中间部分 ...

  4. Nodejs + express + ejs 之服务器demo

    var http=require("http"); var express=require("express"); var fs = require(" ...

  5. Windows环境下,从零开始搭建Nodejs+Express+Ejs框架(一)---安装nodejs

    第一步,安装nodejs https://nodejs.org/en/download/ 这个是nodejs的官网,由于操作系统是win7 64位的,所以,我下载的是node-v8.11.1-x64的 ...

  6. nodejs下express+ejs环境搭建

    nodejs下express+ejs环境搭建   分类: Nodejs 1.进入需要创建项目的目录    cd F:\nodeCode     2.创建一个带ejs模板工程,工程名为haha    e ...

  7. nodejs创建express+ejs项目

    很多同学跟着 node.js开发指南 学习用 express+ejs 创建项目的时候,却总是无法成功,如: 运行 以下命令去创建 express+ejs 创建项目 $ express -t ejs m ...

  8. NodeJS+Express+MongoDB 简单实现数据录入及回显展示【适合新人刚接触学习】

    近期在看NodeJS相关 不得不说NodeJS+Express 进行网站开发是很不错,对于喜欢玩JS的来说真是很好的一种Web开发组合 在接触NodeJS时受平时Java或者C#中API接口等开发的思 ...

  9. 【重点突破】—— Nodejs+Express+MongoDB的使用基础

    前言:最近学习vue和react的高阶项目,都需要和Nodejs+Express+MongoDB结合实现全栈开发.这里结合实例Demo和所学项目集中总结一下这部分服务端的基础知识. 一.Express ...

随机推荐

  1. POJ 3468 A Simple Problem with Integers(线段树:区间更新)

    http://poj.org/problem?id=3468 题意: 给出一串数,每次在一个区间内增加c,查询[a,b]时输出a.b之间的总和. 思路: 总结一下懒惰标记的用法吧. 比如要对一个区间范 ...

  2. Codeforces Round #307 (Div. 2) D. GukiZ and Binary Operations 矩阵快速幂优化dp

    D. GukiZ and Binary Operations time limit per test 1 second memory limit per test 256 megabytes inpu ...

  3. 《F4+2 团队项目需求分析改进》

    a.分析<动态的太阳系模型项目需求规格说明书>初稿的不足. 任务概述描述的有些不具体,功能的规定不详细,在此次作业进行了修改. b.参考<构建之法>8.5节功能的定位和优先级, ...

  4. vue 脚手架(一,创建脚手架)

    本文以转移至本人的个人博客,请多多关注! 本文以转移至本人的个人博客,请多多关注! 本文以转移至本人的个人博客,请多多关注! 本文以转移至本人的个人博客,请多多关注! 经过一段时间对Vue的学习.觉得 ...

  5. C#用大石头Xcode做数据底层注意事项

    1.记得添加XCode.dll 和NewLife.Core.dll 2.记得把程序的框架改为 .net Framework4

  6. hadoop 集群配置--增加减少新的机器不重启

    增加机器不重启操作如下: 首先,把新节点的 IP或主机名 加入主节点(master)的 conf/slaves 文件. 然后登录新的从节点,执行以下命令: $ cd path/to/hadoop $ ...

  7. uva10655矩阵快速幂

    a^(n+2)+b^(n+2)=(a+b)*(a^(n+1)+b^(n+1))-a*b*(a^n+b^n) 坑爹的题目关系式都推出来了居然还是wa了..... 不能只看p,q=0就退出,因为a,b不一 ...

  8. UVA-1336 Fixing the Great Wall(区间DP)

    题目大意:长城(视作x正半轴)有n处破损.有一个智能修复机器人,它的初始位置和移动速度已知.每处破损处都有一组参数(x,c,d),x表示位置,c.d表示在时间t后再修复该处破损的花费为d*t+c.求用 ...

  9. 在页面和请求中分别使用XML Publisher生成PDF报表且自动上传至附件服务器

    两个技术要点: 1.使用TemplateHelper.processTemplate方法生成目标PDF的InputStream流,再使用ftp中上传流的方法将其上传至附件服务器. 2.在请求中调用AM ...

  10. IOS-网络(数据安全:MD5加密)

    // // ViewController.m // IOS_0129_HTTP请求 // // Created by ma c on 16/1/29. // Copyright © 2016年 博文科 ...