Express是目前最流行的基于Node.js的Web开发框架,提供各种模块,可以快速地搭建一个具有完整功能的网站。
Express的上手非常简单,首先新建一个项目目录,假定叫做hello-world。
$ mkdir hello-world
进入该目录,新建一个package.json文件,内容如下。
{
"name": "hello-world",
"description": "hello world test app",
"version": "0.0.1",
"private": true,
"dependencies": {
"express": "4.x"
}
}
上面代码定义了项目的名称、描述、版本等,并且指定需要4.0版本以上的Express。
然后,就可以安装了。
$ npm install
安装了Express及其依赖的模块以后,在项目根目录下,新建一个启动文件,假定叫做index.js。
var express = require("express");
var app = express();
app.use(express.static(__dirname + "/public"));
app.listen(8080);
上面代码运行之后,访问http://localhost:8080
,就会在浏览器中打开当前目录的public子目录。如果public目录之中有一个图片文件my_image.png,那么可以用http://localhost:8080/my_image.png
访问该文件。
你也可以在index.js之中,生成动态网页。
// index.js
var express = require("express");
var app = express();
app.get("/", function (req, res) {
res.send("Hello world!");
});
app.listen(3000);
然后,在命令行下运行下面的命令,就可以在浏览器中访问项目网站了。
$ node index
默认情况下,网站运行在本机的3000端口,网页显示Hello World。
index.js中的app.get
用于指定不同的访问路径所对应的回调函数,这叫做“路由”(routing)。上面代码只指定了根目录的回调函数,因此只有一个路由记录。实际应用中,可能有多个路由记录。
// index.js
var express = require("express");
var app = express();
app.get("/", function (req, res) {
res.send("Hello world!");
});
app.get("/customer", function(req, res){
res.send("customer page");
});
app.get("/admin", function(req, res){
res.send("admin page");
});
app.listen(3000);
这时,最好就把路由放到一个单独的文件中,比如新建一个routes子目录。
// routes/index.js
module.exports = function (app) {
app.get("/", function (req, res) {
res.send("Hello world");
});
app.get("/customer", function(req, res){
res.send("customer page");
});
app.get("/admin", function(req, res){
res.send("admin page");
});
};
然后,原来的index.js就变成下面这样。
// index.js
var express = require("express");
var app = express();
var routes = require("./routes")(app);
app.listen(3000);