为了账号安全,请及时绑定邮箱和手机立即绑定

如何在 Phoenix (Elixir) 渲染中使用变量注入 HTML/操作 DOM

如何在 Phoenix (Elixir) 渲染中使用变量注入 HTML/操作 DOM

蓝山帝景 2023-03-24 15:31:39
如果我有一些 svg 通过分配给视图,比如一个svg变量,我可以渲染到视图中:<%= @svg %>但是,在 DOM 中,我可以检查页面并智能地看到 phoenix 默认不呈现 SVG,因为它是字符串表示形式。但是,我无法弄清楚如何覆盖该默认值,以便我可以正确地注入 dom/渲染 SVG 而不仅仅是在页面中显示字符串,而是实际渲染图像。我该怎么做?我是否必须在事后使用 javascript 进行渲染——这也可以,但只在服务器端渲染就更好了。非常感谢!
查看完整描述

1 回答

?
喵喵时光机

TA贡献1846条经验 获得超7个赞

为了不对内容进行转义,您可以使用该Phoenix.HTML.raw/1功能。

这是 SVG QRCode 生成的示例:

<section>

  <p style="text-align:center">

    <%=

      Routes.some_path(MyApp.Endpoint, :index, @some_id)

      |> QRCode.create!(:high)

      |> QRCode.Svg.create()

      |> raw()

    %>

  </p>

</section>

生成内联 SVG。请注意,该raw/1函数会自动导入到模板中。


查看完整回答
反对 回复 2023-03-24
  • 1 回答
  • 0 关注
  • 90 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信