nodejs+express+ejs+mongoose实例

nodejs+express+ejs+mongoose实例

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源码

时间: 2024-10-05 06:16:32

nodejs+express+ejs+mongoose实例的相关文章

Nodejs + express + ejs

特性 <% %> 用于控制流 <%= %> 用于转义的输出 (会对数据字符进行转义) // 数据源 // app.js var tem={ title:"我是中间部分", info:[{Name:"davi", Time:1497591600000},{name:"bill", Time:1497591600000},{name:"can", Time:1497591600000}] }; // ind

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

安装Express,ejs的前提是一定要先安装nodejs,具体安装方法请查看 http://www.cnblogs.com/tfiremeteor/p/8973105.html 安装Express和ejs的前提是先要创建一个项目,因为我采用的并不是全局安装的方式,顺序为,创建项目,安装Express,再安装ejs. 一.  准备工作. 关于Nodejs的所有操作都必须通过命令行来实现,并且需要进入项目所在的目录.所以,首先运行cmd,打开命令提示符.如下图 这个是默认的路径,现在要进入项目路径

Nodejs + express + ejs 之服务器demo

var http=require("http"); var express=require("express"); var fs = require("fs"); var bodyParser = require('body-parser'); var Common = require("./publice/common"); var app=express(); // 定时器 var refTimer = null; var

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

第一步,安装nodejs https://nodejs.org/en/download/ 这个是nodejs的官网,由于操作系统是win7 64位的,所以,我下载的是node-v8.11.1-x64的版本.linux的同学请直接无视这篇文章吧. 安装时务必选择全部组件,包括勾选Add to Path.如下图 此时,我们可以注意到上图中的安装选项,第二个是npm的包,用来管理各种nodejs开发中所需要的插件.类似于vs中的Nuget.之前是需要单独安装的,现在已经整合到安装包,不需要额外安装了.

Nodejs+express+mongodb+mongoose(一)

Nodejs express中创建ejs项目,解决express下默认创建jade,无法创建ejs问题

最近在看<Node.js开发指南>,看到使用nodejs进行web开发的时候,准备创建ejs项目遇到问题了, 书上命令为: ? 1 express -t ejs microblog 可是执行后,仍旧创建的是jade项目. 原来,express3.x,express4.x中创建ejs命令更新为: express -e microblog //即ejs,-j(即jade)  当然,最直接的,你也可以修改package.json里的定义来实现安装ejs. PS:建立工程过程 1.必须得安装expre

Nodejs express中创建ejs项目 error install Couldn&#39;t read dependencies

最近在看<Node.js开发指南>,看到使用nodejs进行web开发的时候,准备创建ejs项目遇到问题了 书上命令为: express -t ejs microblog 可是执行后,仍旧创建的是jade项目. 原来,express3.x,express4.x中创建ejs命令更新为: express -e microblog //即ejs,-j(即jade) 当然,最直接的,你也可以修改package.json里的定义来实现安装ejs. PS:建立工程过程 1.必须得安装express框架把:

Nodejs学习-2 express ejs 片段视图

在Express框架下,使用ejs模板引擎: 支持默认的layout布局需要express-partials模块: 使用include代替partials: 片段视图显示方式也与3.x版不同,采用如下方式: routers/index.js 添加: router.get('/list', function(req, res) {   res.render('list',{     layout:false,     title: 'Express',     items: ['1', '2', 

使用nodejs+express+mongodb开发web的例子

介绍:简单的介绍下nodejs+express+mongodb这三者. nodejs:是运行在服务器端的程序语言,表面上看过去就是javascript一样的东西,实际是由c++开发是服务器语言. express:是nodejs的一种web框架,node有很多的开源框架,express是一个大神开发的(这尊神已经移驾到go语言的开发去了).express可以让你更方便的操作node(因为直接用nodejs写web比较麻烦,nodejs是事件驱动的,所以有很多异步回调,写多了就看着晕...) mon