nodejs+express+ejs+mongoose實例

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

EJS快速入門教程

三、mongoose

mongoose2.7.0文檔

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、源碼

程序員不是求源碼,就是求無碼。

todo源碼

做者: 像少年啦飛馳
本文版權歸做者和博客園共有,歡迎轉載,但未經做者贊成必須保留此段聲明,且在文章頁面明顯位置給出原文鏈接,不然保留追究法律責任的權利.
相關文章
相關標籤/搜索