准备
使用 $npm install http-f2e-server@0.0.8
进行安装之前版本,本篇在此基础上利用中间件的模式增加功能,对诸如LESS、jade、coffeeScript文件文本的动态解析输出。
添加依赖
middleware的一些模块, 我们使用开发依赖不在安装http-f2e-server的时候直接下载。
因此添加依赖的时候放在devDependencies参数上面。
"devDependencies": { "jade":">=1.7.0", "coffee-script": ">=1.8.0", "less": "2.0.0", "markdown":">=0.5.0" },
然后 npm install
安装所有中间件依赖模块
添加模块入口
因为中间件都是对字符串的操作,我将入口放在 mime.isTXT(pathname)
条件下。可以根据自己需求,放在跟handle模块同级或者内部判断, 原版 f2e-server 是和handle模块并行的,这版处理的时候使用在handle模块里面。
var compiled = _.template(str), result = compiled({require: require,request:req,response:resp}), mw;if( mw = middleware[ req.url.match(/\b(\w+)$/)[1] ] ){ mw(str,root,req,resp); }else{ return str; }
在middleware内部
创建中间件模块,依次根据各种文件后缀名创建解析方法,在内部使用resp输出结果,首先创建最简单的markdown解析, 如下:
"use strict";var mime = require("./mime");module.exports = { md: function(str,root,req,resp){ resp.writeHead(200,{"Content-Type": mime.lookup('html')}); var output = require( "markdown" ).markdown.toHTML(str + ''); resp.end( '<style>code{padding:2px 8px;background:#eee;}</style>' + output, "utf-8" ); } };
markdown模块相关的API可以查看github:https://github.com/evilstreak/markdown-js
这里完成后,直接从浏览器访问 http://localhost:8888/README.md 就能够获取到markdown解析结果HTML了
添加更多解析器
LESS
因为LESS后缀在mime中不能获取到和css一样的type,我们需要去修改包装的mime对应方法lookup
var mime = require("mime");module.exports = { isTXT: function(path){ return /\b(text|xml|javascript|json)\b/.test( this.lookup(path) ); }, lookup: function(path){ if( /\bless\b/.test(path) ){ return mime.lookup("css"); }else{ return mime.lookup(path); } } };
然后添加less解析器
less: function(str,root,req,resp){ require("less").render(str, function (err, output) { if (err) { throw err } else{ resp.end( output.css ); } }); }
但是事实上,你去直接访问对应的less文件链接的时候服务端竟然返回空, 这是由于在主模块中...
else if( mime.isTXT(pathname) ){ rs.on("end",function(){ str = require("./lib/handle").execute(str, root, req, resp); //将处理过程用一个新的模块实现 resp.end( str ); }); }
把handle模块的执行结果已经当作字符串输出到响应中,但是在LESS解析器模块中的处理过程是异步监听机制的,我们需要修改这里当没有数据返回的时候不要使用响应输出。
else if( mime.isTXT(pathname) ){ rs.on("end",function(){ str = require("./lib/handle").execute(str, root, req, resp); //将处理过程用一个新的模块实现 if(typeof str != "undefined") resp.end( str ); //只有返回结果不是undefined时,才直接输出 }); }
然后再次测试,你对应的LESS资源, ! 妥妥的了 !
更多解析器
可以自行查看更多相关模块的API (查看各个模块的package.json中的git地址查看)
PS:
相关完整代码已经发布到了npm仓库中, 可以使用 $npm install http-f2e-server@0.0.9
进行安装或者更新。进入目录后使用 $node http-f2e-server.js
启动服务,并查看Demo。
作者:云香水识
链接:https://www.jianshu.com/p/db384e97ffd3