nodejs學得異常痛苦,在這裏將學的東西作一番整理,算是自我安慰吧。根據網上todo示例,用express和mongoose重寫了部分代碼,主要是業務邏輯這塊(CRUD),這個沒什麼難度。目前還沒有解決的問題是:express不能使用ejs layout template,查了很久也沒解決,知道的麻煩告訴我一下。css
1、代碼目錄html
2、第三方模塊node
一、express程序員
(1)express中文入門指引手冊數據庫
(2)nodejs中文電子書express
(3)如何在WebStorm中創建express工程?npm
安裝expressapp
npm install express
安裝成功後在node_modules下會找到express目錄,同時也會找到.bin目錄,它裏面有express命令腳本框架
在終端下執行mongoose
express project_name
project_name爲實際的nodejs工程名/路徑 好比筆者:E:/Nodejs/todo
(4)Express官方文檔
二、ejs
三、mongoose
Mongoose-讓NodeJS更容易操做Mongodb數據庫
3、核心介紹
一、使用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); }); }
二、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('/'); }); };
三、使用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模板,具體是怎麼設置的?!知道的麻煩說一下,謝謝~~~
4、源碼
程序員不是求源碼,就是求無碼。