node.js - 将文档字段呈现为 HTML

标签 node.js express swig-template

我正在使用 NodeJS、Express、MongoDB 和 Swig 创建我的第一个示例代码。这是一个小型博客应用程序,我正在尝试呈现现有帖子,但是,帖子正文包含 HTML 标签,并且它们被打印为文本。

如何将它们呈现为 HTML?

这是我的观点(main.html):

<p>
    <h3>{{title}}</h3>
    <h6><i>{{postedAt}}</i></h6>
</p>
<p>
    {{content}}
</p>

这是 app.js:

var express = require('express');
var cons = require('consolidate');
var app = express();
var MongoClient = require('mongodb').MongoClient;
var Server = require('mongodb').Server;


app.engine('html', cons.swig);
app.set('view engine', 'html');
app.set('views', __dirname + '/views');

var mongoClient = new MongoClient(new Server('localhost', 27017, 
                                             { 'native_parser' : true }));

var db = mongoClient.db('blog');

// Base URL - Show posts
app.get('/', function (request, response) {
    var cursor = db.collection('posts').find().sort({'postedAt': 1});

    cursor.each(function (err, doc) {
        if (err) throw err;

        if (doc == null) {
            return db.close();
        }

        response.render('main', doc);
    });
});



app.get('*', function (request, response) {
    response.send('Page not found', 404);
});

mongoClient.open(function (err, client) {

    if (err) throw err;

    app.listen(8080);
    console.log('Express started listening on port 8080');
});

最佳答案

Swig HMTL 默认转义所有变量。

如果您确定相关内容是安全的(即 HTML 不包含恶意 JavaScript),那么您可以使用 the safe filter 关闭 HMTL 转义:

<p>
    <h3>{{title}}</h3>
    <h6><i>{{postedAt}}</i></h6>
</p>
<p>
    {{content|safe}}
</p>

关于node.js - 将文档字段呈现为 HTML,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/24337959/

相关文章:

node.js - 也可以将使用 Microsoft Bot Framework 构建的 Bot 连接到其他连接器/ channel

node.js - 是否可以在保存/上传图像之前使用 Multer 获取图像尺寸(宽度和高度)

javascript - Mongoose 错误填充虚拟

internationalization - 如何从 Swig 自定义标签/过滤器中的本地人读取变量?

node.js - 正确地从Axios调用中引发错误

javascript - 找不到 Npm 模块 ""。安装了吗?

node.js - Mongoose:它对未找到的引用有什么作用?

express - 使用Visual Studio Code调试ExpressJS服务器端代码

javascript - 当与其他 View 不在同一文件夹中时,Swig 标签在索引文件中不起作用

node.js - 使用 Swig 的 Express 生成器