如何阻止Django转义#符号

时间:2016-11-21 20:28:33

标签: python django svg escaping

我正在尝试将SVG精灵用于网站中的图标,如下所示:

<svg aria-hidden="true" class="icon">
    <use xlink:href="{% static 'images/site-icons.svg#icon-twitter' %}"></use>
</svg>

然而这不起作用,因为#jando会逃脱#,所以我最终得到:

<svg aria-hidden="true" class="icon">
    <use xlink:href="/static/images/site-icons.svg%23icon-twitter"></use>
</svg>

因此没有图标呈现。 我已经发现问题是逃避,因为如果我将site-icons.svg的内容粘贴到模板中,它就可以了,并且

<svg aria-hidden="true" class="icon">
    <use xlink:href="#icon-twitter"></use>
</svg>

所以问题在于逃避。

有人知道如何避免这种逃避现象吗?

1 个答案:

答案 0 :(得分:5)

您需要在静态标记

之后移动id
{% static 'images/site-icons.svg#icon-twitter' %}

应该是

{% static 'images/site-icons.svg' %}#icon-twitter

这背后的原因是静态标签的工作是找到静态文件的路径,所以它需要的只是文件的位置,之后需要添加任何额外的东西,以便在渲染模板时,它显示为单个(连接?)链接