django模板与vue.js冲突问题

Posted DevOps

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了django模板与vue.js冲突问题相关的知识,希望对你有一定的参考价值。

问题:

django模板与vue.js的变量都是使用“{{”和“}}”包裹起来的,在渲染django模板时会先替代掉所有的“{{”和“}}”及被包裹在其中的内容,使得vue.js没有使用"{{"、"}}"来绑定变量。

处理方法:

方法1:修改vue.js的默认的绑定符号

Vue.config.delimiters = ["[[", "]]"];

执行这个之后,你就可以使用“[[”、“]]”来绑定变量的数据了

方法2:使用模板的标签来输出“{{”、“ }}”

django模板的templatetag 可以渲染模板时输出模板标签,标签参数及输出如下:

参数 输出
openblock {%
closeblock %}
openvariable {{
closevariable }}
openbrace {
closebrace }
opencomment {#
closecomment #}

我们可以在模板中用

{% templatetag openvariable %} {% templatetag closevariable %}

来替代"{{"、"}}"

方法3:禁用django模板渲染

django标签 verbatim可以使包裹其中的代码不进行渲染保持原样输出

{% verbatim %}
    {{ vue }}
{% endverbatim %}

我们可以在需要用于vue.js的地方使用{% verbatim %} {% endverbatim %}包裹。


欢迎关注运维自研堂订阅号,运维自研堂是一个技术分享平台,主要是运维自动化开发:linux、python、django、saltstack、tornado、bootstrap、redis、golang、docker、etcd等经验分享。



牛人并不可怕,可怕的是牛人比我们还努力!





以上是关于django模板与vue.js冲突问题的主要内容,如果未能解决你的问题,请参考以下文章

vue.js与后台模板引擎“双花括号”冲突时的解决办法

Twig 和 Vue.js 的模板冲突

使用 Vue 模板清晰地分离视图和代码

问题将 vue.js 前端与我的 django 后端集成

AngularJS 与 Django - 模板标签冲突

AngularJS 与 Django - 冲突的模板标签