[英]How to let external JSON for Jade to render from Express?
我是Node / Express的初学者,我想使用Jade和Express服务我的静态文件。
以前,我将Jade与gulp-jade和gulp-data结合使用,我将能够呈现Jade文件并使用具有JSON文件的gulp-data呈现每个页面。
index.jade
+ index.json
将给我index.html
的输出
现在,我在如何使用Express将外部JSON文件包括到Jade中时遇到了麻烦。
例如:
server.js
app.get('/', function(req, res){
res.render('pages/index', {pagetitle: 'Hello World'});
});
页/ index.jade
h2 #{pagetitle}
这将导致
<h2>Hello World</h2>
问题
我想将{pagetitle: 'Hello World'}
替换为外部json文件,即index.json。 我可以这样做吗?
app.get('/', function(req, res){
res.render('pages/index', 'folder_name/index.json');
});
肯定是错的,对吧?
是的,这是错误的。 这会将字符串本身设置为模型。 您可能需要看一下NodeJS的fs
模块。 这将使您可以读取文件的内容。 然后,您可以解析JSON并将结果对象作为模型发送到您的Jade模板。
不要忘记异步读取JSON,否则您将阻塞服务器。
https://nodejs.org/api/fs.html
下一步将是创建一个负责读取此文件的模块,将其保存在内存中,并仅在使用观察程序进行更改时才重新加载它。
感谢您的帮助@gretro。
在您的帮助下,我能够解决我的问题。
这是我的解决方案:
var renderFromJson = function(json_path, renderTemplate) {
fs.readFile(json_path, function(err, data) {
renderTemplate(JSON.parse(data));
})
}
app.get('/', function(req, res){
renderFromJson('datas/index.json', function(json_data) {
res.render('pages/index', json_data);
});
});
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.