`

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);

 

 

本文转自:http://www.cnblogs.com/flyoung2008/archive/2012/07/22/2603791.html

分享到:
评论

相关推荐

    nodejs + express + mongoose demo

    【标题】"Node.js + Express + Mongoose Demo"是一个基于Node.js、Express框架和Mongoose库的示例项目,展示了如何构建一个与MongoDB数据库交互的Web应用。 【描述】这个项目不仅是一个简单的Demo,还包含了相关的...

    nodejs+mongodb+express+ejs+connect-mongo

    **Node.js + MongoDB + Express + EJS + Connect-Mongo 知识点详解** Node.js 是一个基于 Chrome V8 引擎的 JavaScript 运行环境,它允许开发者在服务器端使用 JavaScript,提供了丰富的库和框架来简化开发流程。在...

    nodejs + express + ejs + mongodb 一个非常简单的前后端开发的实例

    在本实例中,我们将探讨如何使用Node.js、Express框架、EJS模板引擎和MongoDB数据库进行前后端开发。这是一个基础的Web应用搭建流程,适合初学者理解和实践。 首先,让我们从Node.js开始。Node.js是一个基于Chrome ...

    nodejs+express入门小例子

    1. **设置Express应用**:创建一个基本的Express应用,通过`const express = require('express')`引入Express库,并用`const app = express()`初始化应用实例。 2. **中间件使用**:应用可能使用Express的内置...

    采用NodeJs+Express+MongoDB构建的个人博客系统

    【标题】:“采用NodeJs+Express+MongoDB构建的个人博客系统” 【描述】:这个项目是基于Node.js、Express框架以及MongoDB数据库构建的个人博客系统,它展现了如何使用这些技术栈来创建一个功能完备的Web应用。Node...

    Node-Chat-Demo:Nodejs+Express+MongoDB实例教程

    【Node-Chat-Demo: Nodejs+Express+MongoDB实例教程】 这个教程是关于使用JavaScript的后端框架Node.js、Web应用框架Express以及NoSQL数据库MongoDB构建一个实时聊天应用程序的详细指南。以下是你需要知道的关键...

    shinichi:nodejs+expressjs+mongoose+mongodb

    标题 "shinichi:nodejs+expressjs+mongoose+mongodb" 暗示了一个使用Node.js、Express.js、Mongoose和MongoDB构建的项目。这是一个典型的JavaScript后端开发环境,通常用于快速开发Web应用程序。接下来,我们将深入...

    ginger:nodejs + express + mongodb 后端

    这个名为"Ginger"的项目就是这样一个实例,它结合了这三个强大的工具,提供了灵活的数据存储和处理能力。下面将详细阐述这个技术栈中的各个组成部分及其相关知识点。 首先,Node.js是基于Chrome V8引擎的JavaScript...

    vidly:nodejs +表达

    在主入口文件中引入并实例化Express。 3. **路由配置**:在`routes`文件夹下,为不同的URL路径创建对应的路由处理器,例如处理视频上传、播放、搜索等功能。 4. **中间件使用**:利用中间件处理请求和响应,例如...

    nodejs-express

    8. **Express 应用实例** - 创建 RESTful API,处理 CRUD 操作。 - 使用路由参数、查询参数和请求体数据。 - 实现认证和授权功能,如 JSON Web Tokens (JWT)。 9. **社区支持和插件** - Express 有庞大的社区...

    nodejs-express-mongodb-website:使用nodejs、express、mongodb网站

    - **初始化Express应用**:创建Express实例,设置中间件,定义路由。 - **连接MongoDB**:使用Mongoose建立与MongoDB的连接,定义模型以映射数据结构。 - **路由处理**:根据需求设置GET、POST等路由,处理请求并...

    Node.js-《nodejs开发指南》microblog实例express4.15.x版

    《Node.js开发指南》中的microblog实例是学习Node.js与Express框架的理想实践项目,它基于Express 4.15.x版本。Express是一个轻量级、灵活的Node.js Web应用框架,用于构建Web服务,简化HTTP服务器的创建。在这个...

    Express 4.x版nodejs微博实例

    配置Express使用EJS: ```javascript app.set('view engine', 'ejs'); app.use(express.static('public')); ``` 8. **部署**:最后,将应用部署到云服务器,如Heroku或DigitalOcean,以便其他人可以访问。 ...

    express mvc简单实例

    在Node.js和Express中,模型通常是数据库操作的抽象,例如使用ORM(对象关系映射)库如Sequelize或Mongoose来与数据库交互。 2. **视图(View)**:负责展示用户界面。在Express中,视图通常由模板引擎如EJS、Pug或...

    nodejs-express-app

    2. **app.js**或**index.js**:通常这是Express应用的主入口文件,初始化Express实例并设置路由。 3. **routes**目录:存放应用的路由定义,不同的HTTP请求会被映射到不同的处理函数。 4. **views**目录:存储EJS、...

    WebService:使用 NodeJS、EJS 和 MongoDB 的 Web 服务示例

    2. **安装依赖**:在项目开始前,需要通过 npm(Node Package Manager)安装所需的依赖,包括 express、ejs 和 mongoose(用于 NodeJS 与 MongoDB 交互的库)。 3. **连接 MongoDB**:使用 mongoose 库,编写连接...

    nodejs-express-mongodb-example-app-master

    标题 "nodejs-express-mongodb-example-app-master" 暗示这是一个使用 Node.js、Express 和 MongoDB 构建的示例应用程序。这个项目可能是为了教学目的,帮助开发者了解如何在实际环境中整合这三种技术。 Node.js 是...

    VidlyNodeJS:使用NodeJS和Express构建的NodeJS应用

    VidlyNodeJS是一个基于Node.js和Express框架构建的应用实例,展示了如何利用这两个强大的工具来开发Web应用程序。Node.js是一个开放源代码、跨平台的JavaScript运行环境,它允许开发者在服务器端运行JavaScript代码...

    NodeJS_blog:基于 Express 框架的简单博客构建

    通过`npm install express body-parser ejs mongoose`命令进行安装。 3. **设置Express应用**:创建一个`app.js`文件,导入Express模块并实例化一个应用。配置基本的中间件,如处理静态文件、解析请求体等。 4. **...

    Reeler:基于NodeJS,Express和Mongodb构建的演示电影数据库项目

    `Reeler`项目为初学者提供了了解Node.js全栈开发的实例,涵盖了服务器端编程、数据库操作、路由设计等多个核心概念。通过学习和研究此项目,开发者可以提升在JavaScript后端开发及数据库管理方面的技能,为构建更...

Global site tag (gtag.js) - Google Analytics