express 快速教程
阅读 express 官方文档的记录.
hello world example
var express = require('express')
var app = express()
app.get('/', function(req, res) {
res.send('Hello World')
})
app.listen(3000, function() {
console.log('Example app listening on port 3000!')
})
Routing
路由定义:
app.METHOD(PATH, HANDLER), METHOD 为 HTTP 请求方法, PATH 为路由路径, HANDLER 路由回调函数, 参数为 req, res.
METHOD 还可以为 all, 它的回调函数多一个 next, 作为中间件的功能.
Route paths
路由路径可以为字符串, 字符串模式(?, +, *, () 分别对应正则)以及正则表达式
Route parameters
路由参数是 URL 中的被捕获的特殊位置的片段, 可以通过 req.params 对象获取
app.get('/users/:userId/books/:bookId', function(req, res) {
url = "http://localhost:3000/users/34/books/8989"
req.params = {
userId: "34",
bookId: "8989"
}
})
// 路径参数名字只能为[A-Za-z0-9_]中的字符
// 因此可以使用 '-', '.' 提供一些特殊的功能
app.get('/flights/:from-:to', function(req, res) {
url = 'http://localhost:3000/flights/SH-BJ'
req.params = {
from: 'SH',
to: 'BJ'
}
})
app.get('/plantae/:genus.:species', function(req, res) {
url = 'http://localhost:3000/plantae/Prunus.persica'
req.params = {
genus: 'Prunus',
species: 'persica'
}
})
Route handlers
可以提供多个路由回调函数, 其中一些可以提供类似中间件的功能处理请求, 但是必须要调用 next 以调用下一个回调函数.
Response methods
express 的路由回调函数中的 res 必须调用一下方法以结束请求响应:
- download
- end
- json()
- jsonp
- redirect
- render
- send
- sendFile
- sendStatus
app.route()
使用 app.route() 可以对一个路由链式调用不同的 HTTP 请求
app.route('/book')
.get(function(req, res) {
res.send('Get a random book')
})
.post(function(req, res) {
res.send('Add a book')
})
.put(function(req, res) {
res.send('Update the book')
})
express.Router
express.Router 可以创建一个路由处理模块
var express = require('express');
var router = express.Router();
// middleware that is specific to this router
router.use(function timeLog(req, res, next) {
console.log('Time: ', Date.now());
next();
});
// define the home page route
router.get('/', function(req, res) {
res.send('Birds home page');
});
// define the about route
router.get('/about', function(req, res) {
res.send('About birds');
});
module.exports = router;
以中间件的方式使用 express.Router
var birds = require('./birds')
app.use('/birds'', birds)
中间件
express 中的中间件就是处理 req, res, next 的函数, 中间件函数一般处理模式为:
- 执行任意代码
- 对 req 和 res 进行修改
- 结束 req - res cycle
- next 调用下一个中间件
app 级中间件
app.use 以使用中间件
app.use(function(req, res, next) {
// some code
next()
})
// 对特定路由使用中间件
app.use('/user', function(req, res, next) {
// some code
next()
})
Router 级中间件
Router 级中间件的使用方法和 app 级的相似, 只不过中间件函数绑定在 express.Router 对象上
错误处理中间件
错误处理中间件函数与普通中间件的区别是错误处理多一个参数
app.use(function(err, req, res, next) {
console.error(err.stack);
res.status(500).send('Something broke!');
});
内置中间件
从 express 4.0 版本起, 内置中间件只有一个 express.static
Static
express 内置 express.static(root, ['options']) 中间件处理静态文件.
app.use(express.static('public')) // Express 使用相对路径, 因此 public 不需要在 url 中
app.use(express.static('files')) // 可以使用多个静态中间件, 按照先后顺序查找文件
app.use('/static', express.static('public')) // 添加静态路径到 url 中
第三方中间件
模版
express 默认的模版引擎为 Pug
设置
app.set('views', './views') // 设置模版文件所在目录
app.set('view engine', 'pug') // 如果需要使用其他模版
使用
// 读取模版目录中的 filename 文件, 用 obj 替换模版中的变量
res.render(filename, obj)
Debug
代理设备
express 快速教程的更多相关文章
- Python快速教程 尾声
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 写了将近两年的Python快速教程,终于大概成形.这一系列文章,包括Python基 ...
- 【Python大系】Python快速教程
感谢原作者:Vamei 出处:http://www.cnblogs.com/vamei 怎么能快速地掌握Python?这是和朋友闲聊时谈起的问题. Python包含的内容很多,加上各种标准库.拓展库, ...
- 给深度学习入门者的Python快速教程 - 番外篇之Python-OpenCV
这次博客园的排版彻底残了..高清版请移步: https://zhuanlan.zhihu.com/p/24425116 本篇是前面两篇教程: 给深度学习入门者的Python快速教程 - 基础篇 给深度 ...
- 给深度学习入门者的Python快速教程 - numpy和Matplotlib篇
始终无法有效把word排版好的粘贴过来,排版更佳版本请见知乎文章: https://zhuanlan.zhihu.com/p/24309547 实在搞不定博客园的排版,排版更佳的版本在: 给深度学习入 ...
- Python快速教程目录(转)
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 怎么能快速地掌握Python?这是和朋友闲聊时谈起的问题. Python包含的内容 ...
- Python快速教程 尾声(转)
原文地址: http://www.cnblogs.com/vamei/p/3603046.html 作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留 ...
- 发布《Linux工具快速教程》
发布<Linux工具快速教程> 阶段性的完成了这本书开源书籍,发布出来给有需要的朋友,同时也欢迎更多的朋友加入进来,完善这本书: 本书Github地址:https://github.com ...
- Python快速教程
作者:Vamei 出处:http://www.cnblogs.com/vamei 欢迎转载,也请保留这段声明.谢谢! 怎么能快速地掌握Python?这是和朋友闲聊时谈起的问题. Python包含的内容 ...
- AFNnetworking快速教程,官方入门教程译
AFNnetworking快速教程,官方入门教程译 分类: IOS2013-12-15 20:29 12489人阅读 评论(5) 收藏 举报 afnetworkingjsonios入门教程快速教程 A ...
随机推荐
- [BZOJ 3191][JLOI 2013]卡牌游戏
觉得这题很有必要讲一下! 现在发现在做概率题,基本是向 dp 和 马尔可夫链 靠齐 但是这一题真是把我坑了,因为状态太多,马式链什么的直接死了 我一开始的想法就是用 f[i][j] 表示剩余 i 个人 ...
- js中的this指针(五)
js中的函数有一个很有意思的地方,即函数自身也方法. apply方法让我们可以建立一个参数数组并用其来调用函数. apply方法接受两个参数,第一个是将被绑定给 this 的值.第二个就是一个参数数组 ...
- MyBatis学习(二)
前言 昨天的博客简单的记录了MyBatis的起源.作用.配置以及一个简单的查询例子.写到一半的时候,觉得已经学会了MyBatis,可是全写完的时候才发现,如果多个参数查询,如何表的名字与类字段名不一样 ...
- [mobi文件格式详细介绍一]_[资料篇]
Amazon 收购 Mobipocket 于 2005年3月: Kindle 第一版于2007发布,mobi成为其系统支持的电子格式之一,mobi是由kindle带动发展起来的; 有人问Amazon为 ...
- coffeeScript中类的继承[学习篇]
只是在看深入浅出coffeescript中感觉真的很好,不光是coffe写法简单,生成的js也值得学习,废话不多说了,直接抄个书上的例子 class Pet constructor: -> @i ...
- C#将exe运行程序嵌入到自己的winform窗体中
以下例子是将Word打开,然后将它嵌入到winform窗体中,效果如下图:C将exe运行程序嵌入到自己的winform窗体中 - kingmax_res - iSport注意:该方法只适用于com的e ...
- [PHP] - Laravel - 修改laravel_session的cookie名称
修改Cookie laravel_session的名称方法: 打开文件:config\session.php 找到值:laravel_session 修改为你所需要的cookie名称即可. 当然,还有 ...
- Scss开发临时学习过程
SCSS语法: 假设变量申明带有!default,那么如果在此申明之前没有这个变量的申明,则用这个值,反之如果之前有申明,则用申明的值. ‘...’传递多个参数: @mixin box-shadow( ...
- c++中处理输入输出的方法
============ 怎么处理一行空格中的逗号, ,,, ,,, ,,, c,c,d,d 使用c++的方法,可以这么处理: #include <sstream> #include< ...
- noip 借教室 线段树95分做法
大致的思路是用线段树维护每个区间内部的最小值 段更新最小值 每次查某个区间的最小值是否满足租借要求 满足就借出去 update最小值 注意pushdown操作 还有一个从子区间提取答案的操作 提交地 ...