《node.js開發指南》上面講的代碼案例,如今再來操做的話,確定是運行不成功的。
express如今已是3.x版本,相比書上用到的2.x版本,改動仍是蠻大的。
使用express projectName建立項目時,express的-t參數已經失效,須要手動修改package.json和app.js文件來指定模塊引擎,默認的爲jade;若是須要換成ejs,須要修改: node
- //app.js
- app.set('view engine','ejs');
- //package.json (使用*默認會獲取最新的)
- "ejs":"*";
而後是mongodb,須要使用下面方法: mongodb
- var MongoStore = require('connect-mongo')(express);
express3.x默認已經不支持flash了,你須要先使用npm install connect-flash。而後在app.js中添加以下代碼: express
- //app.js
- var flash = require('connect-flash');
- app.configure(function(){
- app.use(flash()); //app.use(flash());要放在session以前
- });
不支持ejs模塊的partials方法,須要使用npm install express-partials,而後在app.js中添加以下代碼: npm
- //app.js
- var partials = require('express-partials');
- app.use(partials());
在使用res.render時須要顯式傳入模塊可能要用到的變量和數據,在使用partial時,也須要指定。ex: json
exports.index = function(req, res){
- Post.get(null, function(err, posts) {
- if (err) {
- posts = [];
- }
- res.render('index', {
- title: '首頁',
- posts : posts,
- user : req.session.user,
- success : req.flash('success').toString(),
- error : req.flash('error').toString()
- });
- });
- };
須要在render時傳入相應的數據{user:xx, error:xx}
index.ejs中若是須要載入其它ejs文件(例如同級目錄下的posts.ejs文件) session
若是不傳入{posts:posts}的話,posts.ejs在使用posts會報錯。 app
- <%- partial('posts', {posts:posts}) %>