1、用express开发站点时,怎么定义通用的头部和尾部
方案1:用类似asp时代的include添加,如ejs模板:
- <% include ../header.ejs %>
- <h1 class="page-header">
- 这里是内容。
- 注:..表示header.ejs在上一级目录,ejs扩展名可以去掉,直接写:include ../header
- </h1>
- <% include ../footer %>
具体如何应用,大家可以搜索: 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)
反复排查可调试的项目和不能调试的项目,终于发现了,原因就是:
项目所在的路径里,含有中文字符……
记住:开发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);
- }