在静态文件中表达,扩展变量

时间:2013-11-02 09:59:41

标签: javascript node.js express ejs

我在nodejs平台上使用express并使用此指令提供我的javascript库文件

app.use('/static', express.static(__dirname + '/static'))

现在我希望能够在其中一个静态文件中编写类似的东西

[..] var host = <%= host %> [..]

是否有可能在静态服务的文件中扩展变量?

3 个答案:

答案 0 :(得分:1)

以下是您可能希望改进的想法:

var ejs = require('ejs');

//Express.js setup
...

app.use('/public/js/myfile.js', function(req, res){
    var f = ejs.compile('var host = <%= hostname %>;');
    var fileContent = f({hostname: 'somevalue'});
    res.setHeader('Content-Type', 'application/javascript');
    res.setHeader('Content-Length', fileContent.length);
    res.send(fileContent);
});
app.use(express.static(path.join(__dirname, 'public')));

//Routes definition
...

我使用了ejs,因为那是你已经使用的。因此,我们的想法是拥有一个中间件来捕获对这些“动态”javascript文件的请求,并使用模板引擎来编译内容。

请注意,我在这里使用了一个简单的字符串变量,但您可以从磁盘读取该文件然后进行编译。

干杯

答案 1 :(得分:0)

您可以使用loDash's templating表达lodashinexpress

答案 2 :(得分:0)

请在此处查看我的回答:https://stackoverflow.com/a/19812753/2728686

使用 Jade 模板引擎,您可以提供静态文件和将服务器端javascript变量发送到静态HTML文件(或任何jade模板),如下所示:

服务器端(server.js):

app.set('views', __dirname + '/views');
app.set('view engine', 'jade');

app.get('/', ensureAuthenticated, function(request, response){
    response.render('index', { data: {currentUser: request.user.id} });
});

app.use(express.static(__dirname + '/www'));

视图/ index.jade:

!!! 5
script(type='text/javascript')
    var local_data =!{JSON.stringify(data)}

include ../www/index.html