从有关 Express.js 最好的书籍Pro Express.js的作者处学习 Express.js 是个不错的选择。
这个 Express.js workshop 是基于 workshopper 并启迪自 @substack 与 @maxogden 所制作的 stream-adventure 。
ExpressWorks 会提供给您挑战和提示。您针对这些问题写出一个 Express.js app 作为解决方案之后,ExpressWorks 将会验证您的解法是否正确。
视频截图 带你熟悉一下安装流程和可能会出现的问题(剧透): YouTube ExpressWorks. 📺💻😁
这个 workshop 是 Pro Express.js (Apress 2014)的作者 Azat Mardan带给你的.
在开始这段美妙的旅程之前,你可能需要下载 免费 Express.js 速查表, 或者 在线浏览.
- 英语
- 法语
- 简体中文
- 繁体中文
- 韩语
- 日语
95 Azat Mardan
19 Christophe Porteneuve
10 Tyler Moeller
8 Justin Porter
6 billy3321
3 Harry Moreno
3 Charlotte Spencer
3 Kohei TAKATA
2 Julian Mazzitelli
2 Robbie Holmes
2 Shim Won
2 Thomas Burette
2 Austin Corso
2 azat-co
2 Kevin Jayanthan
2 intrueder
1 Timothy Gu
1 Trevor Whitney
1 Wojciech Gawronski
1 brownman
1 raj
1 Alessandro Lensi
1 swisherb
1 Alfredo Miranda
1 Ayman Mahfouz
1 Daniel Geier
1 Dylan Smith
1 Eddie Hsieh
1 Finn
1 Gabe Fernando
1 Giuseppe
1 Jessie Shi
1 Johan Binard
1 Jonny Arnold
1 Kevin Kuhl
1 Louis Pilfold
1 Rich Trott
1 Richard Kho
1 Ryan Kois
发给我们一个 Pull Request,就可以看到您的名字出现在这里。 ;-)
PS: 产生自 git shortlog -n -s
建议将这个程序装在系统里:
$ npm install express
$ npm install -g expressworks
$ expressworks
如果发生错误,尝试这样安装:
$ sudo npm install -g expressworks
$ expressworks
执行以下命令以安装在所在目录:
$ mkdir node_modules
$ npm install expressworks
$ cd node_modules/expressworks
$ node expressworks
注意 : ExpressWorks 需要在当前目录复制一份可用的 express 程序。做挑战之前,请确认已经执行以下命令
$ npm init
$ npm install [email protected]
请前往离线安装环节查看更多需要的依赖.
ExpressWorks 可以使用以下命令:
Usage
expressworks
显示互动式清单,以选择一个 workshop 。
expressworks list
显示所有的 workshop,一行一个。
expressworks select 「workshop 名字」
选择一个 workshop
expressworks current
显示目前已选的 workshop
expressworks run program.js
执行您的程序处理选定的輸入
expressworks verify program.js
验证您的程序是否有预期的输出
如果你提前安装所有 node 包,你就可以离线完成这个 workshop。 这是这个 workshop 支持的所有的带版本号的模块:
$ npm install [email protected]
$ npm install [email protected]
$ npm install [email protected]
$ npm install [email protected]
注意: 在安装依赖之前,你需要在你的项目文件夹中包含node_modules
或 packagen.json
运行$ mkdir node_modules
或 $ npm init
可以创建它们其中之一。
如果您想要重置完成挑战的清单,可以删除 ~/.config/expressworks/completed.json
文件
请参阅 Express.js Guide, Pro Express.js 和 FREE Express.js cheatsheet。
制作一个监听在 localhost:3000 ,当有人打开「/home」页面时会输出「Hello World!」的 Express.js app 。
expressworks 会将监听的 port 放在第一个参数 process.argv[2]
。
制作一个在 Home 页面(/home)以 Pug 模版显示特定信息(toDateString)的 Express.js app 。
编写一个可处理 HTML 表单输入 (<form><input name="str"/></form>
),并接着把字符串倒过来的路由(/form
)
不通过任何路由,将静态 middleware 套用至服务器的 index.html 文件。这个 index.html 文件所在位置将会通过 process.argv[3]
提供给程序。无论如何,您也可以使用含有以下内容的档案:
<html>
<head>
<link rel="stylesheet" type="text/css" href="/main.css"/>
</head>
<body>
<p>I am red!</p>
</body>
</html>
使用 Stylus middleware 为您之前使用的 HTML 文件加上样式。main.styl 文件的所在位置将会通过 process.argv[3]
传给程序,或您也可以用以下的内容建立您自己的文件或目录:
p
color red
index.html 文件:
<html>
<head>
<title>expressworks</title>
<link rel="stylesheet" type="text/css" href="/main.css"/>
</head>
<body>
<p>I am red!</p>
</body>
</html>
建立一个可以处理 PUT /message/:id
请求(如 PUT /message/526aa677a8ceb64569c9d4fb
)的 Express.js 服务器。
这个请求的回应是 id 的 SHA1 哈希值加上一个日期。
require('crypto')
.createHash('sha1')
.update(new Date().toDateString().toString() + id)
.digest('hex')
编写一个会解析GET /search
网址 query 字符串的路由。如 ?results=recent&include_tabs=true
,并把结果转换成 JSON 格式輸输出。
编写一个会读入文件(文件名会以 process.argv[3]
传给程序),并以 JSON 解析文件内容,然后把内容以 res.json(object)
显示出來。