標籤:nodejs express centos
Perface
今天看了一些nodejs,《nodejs開發指南》。看到了expres的時候,因為那本書用的express版本跟我的不一樣,導致很多功能不能實現。所以就各種google,現在就把這個流程記錄下來,遇見的bug和一些原理。
要玩express就要裝nodejs,如果你的作業系統是centos6.5可以參考我之前寫的部落格centos6.5安裝nodejs。其他動作系統也大同小異,可以看Node Installation
Bug
-
1 Express Command not found
-
最初操作:跟著《nodejs開發指南》敲
npm install -g express,安裝好了,就在linux命令列敲
express --help就出現上面的原因了。
-
解決方案:在安裝一個包
npm install -g express-generator
-
原因:express3+已經把建立一個APP的功能分離出來為express-generator,沒它你建立不了應用程式
-
2 express -t ejs microblog建立的不是ejs模板引擎而是jade模板引擎
-
最初操作:跟著《nodejs開發指南》在命令列敲
express -t ejs microblog是用來建立應用程式的,應用程式的名字叫microblog、模板引擎是ejs
-
出現情況:但是通過查看microblog檔案夾中的package.json中知道建立出來的不是ejs模板而是jade模板引擎
-
解決方案:版本不一樣,用錯命令了,應該是
express -e microblog(-e就是ejs模板)
-
3 node app.js沒效果
-
最初操作:跟著《nodejs開發指南》在命令列敲node app.js,然後就用瀏覽器訪問監聽的3000連接埠
-
出現情況:訪問不到頁面
-
解決方案:版本不一樣,用錯命令了,應該是
npm start
Summary
其實簡單入門式用express ejs模板步驟如下
- npm install -g express && npm install -g express-generator
- express -e microblog
- cd microblog & make install
- npm start
- 瀏覽器訪問localhost:3000
成功的頁面如下:
想要更加具體瞭解,可以查看express協助文檔 Express Guide
Theory
其實在之後我還遇見一個bug,這個不是版本的問題,就是我在linux重新開一個終端來輸入命令的時候,目前的目錄是/home/monkindey/Desktop其實就是在案頭,當我輸入npm start時候就報錯了“Error:ENOENT,open‘/home/monkindey/Desktop/package.json‘”,當時我就覺得是不是要切換到express應用程式的目錄去,果然,當切換到應用程式的目錄中,再執行命令npm start就成功了。然後我就有了困惑了。
- 第一、為什麼我npm start要切換到應用程式的目錄裡才能執行
- 第二、為什麼我npm start的時候究竟是跑應用程式哪個檔案?
下面讓我來簡單說一下
- npm 是nodejs的包管理工具,可以使用它來下載包、查看檔案等功能
- 用express建立的應用程式是一個符合CommonJS規範的一個nodejs包
- npm執行的時候會讀取目前的目錄的package.json檔案,這個也就是我上面那個bug出現的原因
- 執行npm start其實是執行package.json中的script對應的對象中的start屬性所對應的命令列,下面是我應用程式的package.json:
所以其實如果吧package.json中的start改成monkindey或者其他字串,然後你在linux命令列敲上npm monkindey/或者其他,程式照樣會運行
其實package.json就是一個設定檔,只是我們之前用的xml格式,但是在nodejs用的是json可以,簡單容易理解。從package.json我們可以看出來npm start其實執行的是./bin/www裡面是建立一個伺服器然後監聽3000連接埠,所以我們可以在瀏覽器中通過輸入"localhost:3000"來訪問應用程式
ReferenceExpress command not found
node.js express npm start
Express Getting started
《nodejs開發指南》