Nodejs開發指南的幾處更新

《node.js開發指南》上面講的代碼案例,如今再來操做的話,確定是運行不成功的。
express如今已是3.x版本,相比書上用到的2.x版本,改動仍是蠻大的。
使用express projectName建立項目時,express的-t參數已經失效,須要手動修改package.json和app.js文件來指定模塊引擎,默認的爲jade;若是須要換成ejs,須要修改: node

 
  1. //app.js
  2. app.set('view engine','ejs');
 
  1. //package.json (使用*默認會獲取最新的)
  2. "ejs":"*";

而後是mongodb,須要使用下面方法: mongodb

 
  1. var MongoStore = require('connect-mongo')(express);

express3.x默認已經不支持flash了,你須要先使用npm install connect-flash。而後在app.js中添加以下代碼: express

 
  1. //app.js
  2. var flash = require('connect-flash');
  3.  
  4. app.configure(function(){
  5. app.use(flash()); //app.use(flash());要放在session以前
  6. });

不支持ejs模塊的partials方法,須要使用npm install express-partials,而後在app.js中添加以下代碼: npm

 
  1. //app.js
  2. var partials = require('express-partials');
  3. app.use(partials());

在使用res.render時須要顯式傳入模塊可能要用到的變量和數據,在使用partial時,也須要指定。ex: json

exports.index = function(req, res){ 

 
 
 

  
  
  
  

 
  1. Post.get(null, function(err, posts) {
  2. if (err) {
  3. posts = [];
  4. }
  5. res.render('index', {
  6. title: '首頁',
  7. posts : posts,
  8. user : req.session.user,
  9. success : req.flash('success').toString(),
  10. error : req.flash('error').toString()
  11. });
  12. });
  13. };

須要在render時傳入相應的數據{user:xx, error:xx}
index.ejs中若是須要載入其它ejs文件(例如同級目錄下的posts.ejs文件) session

若是不傳入{posts:posts}的話,posts.ejs在使用posts會報錯。 app

 
  1. <%- partial('posts', {posts:posts}) %>
相關文章
相關標籤/搜索