如何在 Go 模板中不转义地渲染 HTML?

How to render HTML without escaping in Go templates?

如何在 Go HTML 模板中呈现“安全”HTML?即没有模板引擎转义它?例如如果我从其他地方提取 HTML 片段 - 比如数据库?

具体来说...我有一些存储在字符串中的冗长条款和条件。它们需要在不同的地方使用,它们自己的模板并不是包含它们的理想方式。

必须将所有内容 HTML 都保存在模板中真的很不方便...其他语言有一种方法可以将注入的内容指定为可以安全呈现。

我如何在 Go 中执行此操作?我知道它在某处。我在文档中找不到它。

在处理程序中...

    hello := "<p><i>Hello</i>"
    data["Hello"] = hello
    Render it and pass data...

在模板中...

    <h1>Show Stuff</h1>      
    {{.Hello}}

在浏览器中...

Show Stuff
<p><i>Hello</i>

您可以使用 html/template 的 HTTP type

只需像这样转换您的字符串:template.HTML("your html here")