若是你有 PHP 开发经验,会习惯在修改 PHP 脚本后直接刷新浏览器以观察结果,而你在开发 Node.js 实现的 HTTP 应用时会发现,不管你修改了代码的哪一部份,都必须终止Node.js 再从新运行才会奏效。这是由于Node.js 只有在第一次引用到某部份时才会去解析脚本文件,之后都会直接访问内存,避免重复载入,而 PHP 则老是从新读取并解析脚本(若是没有专门的优化配置)。Node.js的这种设计虽然有利于提升性能,却不利于开发调试,由于咱们在开发过程当中老是但愿修改后当即看到效果,而不是每次都要终止进程并重启。supervisor 能够帮助你实现这个功能,它会监视你对代码的改动,并自动重启 Node.js。node
使用方法很简单,首先使用 npm 安装 supervisor:express
$ npm install -g supervisor
若是你使用的是 Linux 或 Mac,直接键入上面的命令极可能会有权限错误。缘由是 npm须要把 supervisor 安装到系统目录,须要管理员受权,可使用 sudo npm install -g supervisor
命令来安装。npm
接下来,使用 supervisor 命令启动 app.js( 能够视状况更改,好比当前须要启动:supervisor ./bin/www):ubuntu
$ supervisor app.js DEBUG: Running node-supervisor with DEBUG: program 'app.js' DEBUG: --watch '.' DEBUG: --extensions 'node|js' DEBUG: --exec 'node' DEBUG: Starting child process with 'node app.js' DEBUG: Watching directory '/home/byvoid/.' for changes. HTTP server is listening at port 3000.
当代码被改动时,运行的脚本会被终止,而后从新启动。在终端中显示的结果以下:设计模式
DEBUG: crashing child DEBUG: Starting child process with 'node app.js' HTTP server is listening at port 3000.
supervisor 这个小工具能够解决开发中的调试问题。浏览器
全局安装express的时候( npm install -g express),使用express命令失效,有以下两种缘由。服务器
安装的express是4.0以上的版本,express在4.0以后,须要安装the executable(执行器express-generator)才能执行express命令,app
解决方案:函数
安装express-generator便可工具
npm install express-generator -g;
1)若是是用sudo apt-get install nodejs命令安装的nodejs,ubuntu在安装的时候为了不包的冲突,将nodejs的命令操做改为nodejs,而不是node。
2)因为express安装时默认的nodejs命令是node,因此安装完后express命令会不起做用,本人的理解是express命令是在node名字的基础上继续其余操做的:
eg. 它多是这样的 node xxx, 而后在其它命令xxx 因而就组合成了express这一系列的操做,既然node命令都没有用了 那么express天然也就失去了原来的效果
解决方案:
1)若express的版本为4.0以上
去 /usr/local/lib/node_modules/express-generator/bin 目录,改express文件的第一行 ,以下:
#!/usr/bin/env nodejs
2)若express的版本为4.0如下
去 /usr/local/lib/node_modules/express/bin 目录,改express文件的第一行 ,以下:
#!/usr/bin/env nodejs
Express 支持同一路径绑定多个路由响应函数,例如:
app.all('/user/:username', function(req, res) { res.send('all methods captured'); }); app.get('/user/:username', function(req, res) { res.send('user: ' + req.params.username); });
但当你访问任何被这两条一样的规则匹配到的路径时,会发现请求老是被前一条路由规则捕获,后面的规则会被忽略。缘由是 Express 在处理路由规则时,会优先匹配先定义的路由规则,所以后面相同的规则被屏蔽。
Express 提供了路由控制权转移的方法,即回调函数的第三个参数 next ,经过调用next() ,会将路由控制权转移给后面的规则,例如:
app.all('/user/:username', function(req, res, next) { console.log('all methods captured'); next(); }); app.get('/user/:username', function(req, res) { res.send('user: ' + req.params.username); });
当访问被匹配到的路径时,如 http://localhost:3000/user/carbo,会发现终端中打印了 all methods captured ,并且浏览器中显示了 user: carbo 。这说明请求先被第一条路由规则捕获,完成 console.log 使用 next() 转移控制权,又被第二条规则捕获,向浏览器返回了信息。
<% code %> :JavaScript 代码。
<%= code %> :显示替换过 HTML 特殊字符的内容。(在routes的js文件中返回的内容)
<%- code %> :显示原始 HTML 内容。
<%# code %> :注释标签,不执行,也没有输出。
<%%%>: 输出字面的 '<%%>'
-%> :Trim-mode ('newline slurp') 标签, 移除随后的换行符
基本上的意思好像是说已经把headers传递给页面了,因此不能再次设置它们。
出现的缘由:
在layout.ejs中,使用<%- body %>,表示这部份内容是各个模板文件独有的。
在admin.ejs中,又一次使用<%- body %>,就会报错
解决方式:
在admin.ejs中,删掉<%- body %>。
也就是说,admin.ejs做为/uses路由的默认模板,它实际上仍是要经过layout.ejs来进行统一渲染的。由于模板文件不是孤立展现的,默认状况下全部的模板都继承自 layout.ejs
GET:获取POST:新增PUT:更新DELETE:删除HEAD:请求指定资源的响应头TRACE:回显服务器收到的请求,主要用于测试或诊断CONNECT:HTTP/1.1 协议中预留给可以将链接改成管道方式的代理服务器。OPTIONS:返回服务器支持的HTTP请求方法。