1、用express开发站点时,怎么定义通用的头部和尾部
方案1:用类似asp时代的include添加,如ejs模板:
<% include ../header.ejs %> <h1 class="page-header"> 这里是内容。 注:..表示header.ejs在上一级目录,ejs扩展名可以去掉,直接写:include ../header </h1> <% include ../footer %>方案2:用类似于MVC的layout模板,这个要安装一个模块: npm install express-partials
具体如何应用,大家可以搜索: node.js express layout
这里就不详述了
2、Windows下,使用WebStorm8,无法调试express项目,排查了半天,团队里有些人能调试,有些人不能调试,
现象是点击运行,能正常运行站点,但是点击调试,在WebStorm的Console窗口,就会出现进程自动退出的提示:
"C:\Program Files (x86)\JetBrains\WebStorm 8.0.3\bin\runnerw.exe" "C:\Program Files\nodejs\node.exe" --debug-brk=54923 --nolazy bin\www debugger listening on port 54923 Process finished with exit code -1073741510 (0xC000013A: interrupted by Ctrl+C)汗,竟然说是Ctrl+C导致的中断…… 根据这个提示,百度和Google都查了半天,一点消息也没有,
反复排查可调试的项目和不能调试的项目,终于发现了,原因就是:
项目所在的路径里,含有中文字符……
记住:开发node.js项目,文件所在路径,一定不能有中文字符
3、node.js的项目文件一定要用utf-8的编码格式保存,否则文件内容里的中文等双字节字符,就会出问题,出现各种莫名其妙的问题哦
4、node.js开发的站点,只能监听指定端口,不像IIS,不支持多主机头(多域名),如果确实要支持多主机头,只能通过nginx之类的反向代理,映射到不同端口的node.js进程
5、json文件里不支持注释,任何格式的注释都不支持,如 // /* */ <!-- -->.
如果希望添加注释,只能用键值对方案,如:{"a":123, "a的含义": "就是一个数字"}
6、node.js没有类似Asp.net里的Web.config文件,不过可以用一个json对象代替,比如在项目根目录下添加一个settings.js文件,内容如下:
module.exports = { abc : 123, def : "www.baidu.com", mysql:{ host:"192.168.189.100", user:"root", database:"dbTest", port:"3306", password:'123', connectionLimit:10, charset:"utf8" } };然后在其它文件中这么调用:
var mysql = require('mysql'); var settings = require('../settings'); // 获取def属性,输出 console.log(settings.def); // 获取mysql连接信息 var pool = mysql.createPool(settings.mysql);
7、express项目中,直接创建并返回静态html文件
方案1:把html文件放到项目 的public目录下,如/public/abc/def.html
那么请求url就是: http://localhost:3000/abc/def.html
方案2:读取文件后,输出字符串的方式,代码如下:
var express = require('express'); var path = require('path'); var router = express.Router(); router.get('/', function(req, res) { sendHtmlFile(res, "./index.js"); }); module.exports = router; function sendHtmlFile(res, relativePath){ var htmlpath = getAbsPath(relativePath); // 按扩展名自动识别并输出响应的Content-Type res.sendfile(htmlpath); } // 转换相对路径为绝对路径 function getAbsPath(relativePath){ var htmlpath = __dirname + "/" + relativePath; return path.resolve(htmlpath); }