我正在搜索某种模板/宏引擎'对于javascript文件。 我需要做的是将javascript文件提供给浏览器。这些javascript文件大多是静态的,但在某些方面有所不同。
这就是我现在基本上做的事情:
app.get('/api/api.js', function (req, res) {
fs.readFile(
path.join(__dirname, './libraries/api.js'),
{ encoding: 'utf8' },
function (err, data) {
if (err) throw err;
res.set('Content-Type', 'text/javascript');
res.send(data);
});
});
现在我需要在读取文件中添加/替换几行代码,然后再将其提供给客户端。
以下是一些例子:
var host = 'http://mydomain.com/';
var domains = ['mydomain1.com', 'mydomain2.org'];
是的我可以使用基本搜索和替换,但我想知道是否有更通用的解决方案。
答案 0 :(得分:0)
我解决了它写我自己的小渲染引擎,你可以在这里看到:http://jsfiddle.net/g5PEp/
var ApiRenderer = function(fileContent) {
var fileContent = fileContent || '';
var data = {};
function sourroundString(str, char) {
char = char || '\'';
return char + str + char;
}
function render() {
var result = fileContent,
str;
for(var key in data) {
var substr = '/*{{' + key + '}}*/';
if(typeof data[key] === 'string') {
str = sourroundString(data[key]);
}
if(Object.prototype.toString.call( data[key] ) === '[object Array]') {
str = '[';
for(var i = 0; i < data[key].length; i++) {
str += sourroundString(data[key][i]);
if(i !== data[key].length - 1) {
str += ',';
}
}
str += ']';
}
result = result.replace(substr, str);
}
return result;
}
return {
setData: function(key, value) {
return data[key] = value;
},
render: function() {
return render();
}
}
};
目前这对我有用,但我有点难过这不允许我在我的模板中编写有效的javascript代码。