使用node.js提供动态.js文件

时间:2013-11-11 13:48:30

标签: javascript node.js

我正在搜索某种模板/宏引擎'对于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'];

是的我可以使用基本搜索和替换,但我想知道是否有更通用的解决方案。

1 个答案:

答案 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代码。