Django和Angular.js模板标签冲突的解决方式
参考文章:http://yanhua365.lofter.com/post/b417f_1f0361
http://stackoverflow.com/questions/8302928/angularjs-with-django-conflicting-template-tags
说在前面的话,目前新版的Django 模板里面有个verbatim
¶标签,是做这个事情的正途。
这个{{}}标签冲突的问题,在最新版的Django 1.5中提出了模板内建的解决方案 verbatim 标签:https://docs.djangoproject.com/en/1.5/ref/templates/builtins/#verbatim 这个标签内的内容可以避免被服务器端模板解析。使用1.4及之前版本的同学可以考虑用系统内建标签templatetag输出特殊字符串,或者用下面这个方案,就是少写几个字符。特殊定制了一下。至于客户端模板配置的解决方案还是看上面参考文章吧。
主要参考第一篇的文章中间那个,用服务器端标签输出客户端所需的标签的解决方案,因为模板里到处是{{"}}"}}这样的文本容易让人糊涂,所以把输出封装成了Django
的包含标签解决,其中后双大括号的输出还用一个变量,否则输出成歧义。废话补多说了,上代码:
#coding:utf-8 ''''' Created on 2013-7-9 @author: hulda ''' from django import template register = template.Library() @register.inclusion_tag('dlb.djhtml') def dlb(): ''''' double left brace:双左大括号,主要是为解决Django服务器端模板标签和AngularJS客户端模板标签冲突的问题 ''' return {} @register.inclusion_tag('drb.djhtml') def drb(): ''''' double right brace:双右大括号,主要是为解决Django服务器端模板标签和AngularJS客户端模板标签冲突的问题 ''' return {"drb":"}}"}
总结:坦率地讲这种服务器端解决方式,相比于客户端设置可能在性能上会略有缺憾,不过Web站点在性能上产生问题的时候,团队优化能力估计应该也不是问题了。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 如何编写易于单元测试的代码
· 10年+ .NET Coder 心语,封装的思维:从隐藏、稳定开始理解其本质意义
· .NET Core 中如何实现缓存的预热?
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 地球OL攻略 —— 某应届生求职总结
· 周边上新:园子的第一款马克杯温暖上架
· Open-Sora 2.0 重磅开源!
· 提示词工程——AI应用必不可少的技术
· .NET周刊【3月第1期 2025-03-02】