gpt4 book ai didi

javascript - 如何将变量传递给 Pug 的 `script.` block ?

转载 作者:行者123 更新时间:2023-11-29 18:56:38 25 4
gpt4 key购买 nike

我的 index.pug 文件中有这段代码

doctype html
html
head
title= title
body
script(src=`${source}`)
script.
for (var event of events){
VClient.Event.subscribe(event, createDiv);
}

下面是我如何将变量从 Express 传递给 pug。

var express = require('express');
var app = express();
app.set('view engine', 'pug')

app.get('/', function(req, res){
var id = req.query.id || 23717;
var source = `https://some.source.url/${id}.js`;
res.render('index',
{title: 'Preview Embed', source: source, events:["AD_START","AD_COMPLETE"]});
});
app.listen(5000);

titlesource 都进入了 pug 文件。但不是事件:

Uncaught ReferenceError: events is not defined

如何在 script. block 中正确传递变量?

最佳答案

您基本上需要以最终结果作为有效 JS 进行插值的方式呈现您的变量。可以通过以下方式完成:!{JSON.stringify(events)}

for (var event of !{JSON.stringify(events)}) ...

应该扩展为:

for (var event of ["AD_START","AD_COMPLETE"]) ...

请注意 unescaped interpolation!{} ,与更频繁使用的 #{} 相反,在这种情况下,它不起作用,因为它会扩展为类似 ["..."] 的内容(即转义引号)

警告:未转义的代码可能很危险。您必须确保清理所有用户输入以避免跨站点脚本 (XSS)。请参阅:How to pass variable from jade template file to a script file?

关于javascript - 如何将变量传递给 Pug 的 `script.` block ?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/49238052/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com