前言
大家应该都知道,Django和Angular的模板系统使用了非常相似的标签系统,比如说,都是使用{{ content }}
表示变量名字。所以Django和Angular配合使用的时候,会引起冲突。我在网上找到了一些解决方法。现在总结后分享给大家,下面来一起看看吧。
一、 改变AngularJs的默认标签
下面的代码可以将Angular原来的标签改成{[{ content }]}
。
这是比较简单,并且直观的一种方法。修改之后的代码比较容易阅读,一眼就能看出来是Django的标签还是Angular的。缺点是很容易与第三方的插件冲突(如果第三方的插件使用了指令等用到标签的地方)。
二、 告诉Django不要渲染模板的其中一部分内容
从Django 1.5开始,支持{% verbatim %}
标签(verbatim的意思是逐字翻译的,字面意思的),Django不会渲染verbatim标签包裹的内容:
这样,Django会寻找myblock的endverbatim作为结束的标志,中间插入了verbatim标签,会作为myblock中不解释的一部分处理。
这种方案的优点是,不会增加代码的复杂度,并且是Django的原生支持,对Angular也没有影响。缺点是可能在很多地方用到很多verbatim标签,搞得template很乱。
三、 使用第三方插件
目前,我已知的有。这个插件有混合django和angular标签的功能。
正确解析angular标签的同时,还可以继续使用django的if等标签。