• linkedu视频
  • 平面设计
  • 电脑入门
  • 操作系统
  • 办公应用
  • 电脑硬件
  • 动画设计
  • 3D设计
  • 网页设计
  • CAD设计
  • 影音处理
  • 数据库
  • 程序设计
  • 认证考试
  • 信息管理
  • 信息安全
菜单
linkedu.com专业计算机教程网站
  • 网页制作
  • 数据库
  • 程序设计
  • 操作系统
  • CMS教程
  • 游戏攻略
  • 脚本语言
  • 平面设计
  • 软件教程
  • 网络安全
  • 电脑知识
  • 服务器
  • 视频教程
  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure
您的位置:首页 > 网页设计 >AngularJS > 解决Angular.Js与Django标签冲突的方案

解决Angular.Js与Django标签冲突的方案

作者: 字体:[增加 减小] 来源:互联网 时间:2017-05-30

本文主要包含angular js,angular.js下载,angular js菜鸟教程,angular.js官网,angular js完整项目等相关知识,希望在学习及工作中可以帮助到您

前言

大家应该都知道,Django和Angular的模板系统使用了非常相似的标签系统,比如说,都是使用{{ content }}表示变量名字。所以Django和Angular配合使用的时候,会引起冲突。我在网上找到了一些解决方法。现在总结后分享给大家,下面来一起看看吧。

一、 改变AngularJs的默认标签

下面的代码可以将Angular原来的标签改成{[{ content }]} 。

修改Angular的标签

myModule.config(function($interpolateProvider) {
 $interpolateProvider.startSymbol('{[{');
 $interpolateProvider.endSymbol('}]}');
});
</div>

这是比较简单,并且直观的一种方法。修改之后的代码比较容易阅读,一眼就能看出来是Django的标签还是Angular的。缺点是很容易与第三方的插件冲突(如果第三方的插件使用了指令等用到标签的地方)。

二、 告诉Django不要渲染模板的其中一部分内容

从Django 1.5开始,支持{% verbatim %}标签(verbatim的意思是逐字翻译的,字面意思的),Django不会渲染verbatim标签包裹的内容:

{% verbatim %}
 {{if dying}}Still alive.{{/if}}
{% endverbatim %}
</div>

这个标签不支持嵌套,但是你可以为标签添加名字:

{% verbatim myblock %}
 Avoid template rendering via the {% verbatim %}{% endverbatim %} block.
{% endverbatim myblock %}
</div>

这样,Django会寻找myblock的endverbatim作为结束的标志,中间插入了verbatim标签,会作为myblock中不解释的一部分处理。

这种方案的优点是,不会增加代码的复杂度,并且是Django的原生支持,对Angular也没有影响。缺点是可能在很多地方用到很多verbatim标签,搞得template很乱。

三、 使用第三方插件

目前,我已知的有django-angular。这个插件有混合django和angular标签的功能。

正确解析angular标签的同时,还可以继续使用django的if等标签。

{% load djng_tags %}
{% angularjs ng %}
<div{% if ng %} ng-repeat="item in items"{% endif %}>
 <h4><a ng-href="{{ item.absolute_url }}"{% if not ng %} href="{{ item.absolute_url }}"{% endif %}>{{ item.name }}</a></h4>
 <img ng-src="{{ item.image.url }}"{% if not ng %} src="{{ item.image.url }}"{% endif %} width="{{ item.image.width }}" height="{{ item.image.height }}" />
 <div{% if ng %} ng-bind-html="item.description"{% endif %}>{% if not ng %}{{ item.description }}{% endif %}</div>
</div>
{% endangularjs %}
</div>

这样做的缺点是,引入插件增加了代码的复杂度,团队的所有人都需要学习这种写法,我个人感觉,也比较容易增加错误。

我觉得第二种比较合适, 写入变量的时候尽量前后端分开,django负责返回静态的模板,数据交给angular,没大问题。

总结

以上就是这篇文章的全部内容了,希望本文的内容对大家的学习或者工作能带来一定的帮助,如果有疑问大家可以留言交流。

</div>

您可能想查找下面的文章:

  • angular directive的简单使用总结
  • 详解Angular路由 ng-route和ui-router的区别
  • 详解Angular2中Input和Output用法及示例
  • Angular.JS中的this指向详解
  • 详解如何在Angular中快速定位DOM元素
  • Angular中$state.go页面跳转并传递参数的方法
  • Angular.Js中过滤器filter与自定义过滤器filter实例详解
  • Angular.JS内置服务$http对数据库的增删改使用教程
  • Angular2中select用法之设置默认值与事件详解
  • Angular.JS中指令ng-if、ng-show/ng-hide和ng-switch的使用教程

相关文章

  • 2017-05-30AngularJs根据访问的页面动态加载Controller的解决方案
  • 2017-05-30AngularJS 过滤与排序详解及实例代码
  • 2017-05-30详解angular中通过$location获取路径(参数)的写法
  • 2017-05-30AngularJS 实现弹性盒子布局的方法
  • 2017-05-30Angularjs material 实现搜索框功能
  • 2017-05-30Angular路由简单学习
  • 2017-05-30Angularjs中如何使用filterFilter函数过滤
  • 2017-05-30详解支持Angular 2的表格控件
  • 2017-05-30NodeJs——入门必看攻略
  • 2017-05-30AngularJS入门教程之ng-checked 指令详解

文章分类

  • html/xhtml
  • html5
  • CSS
  • XML/XSLT
  • Dreamweaver教程
  • Frontpage教程
  • 心得技巧
  • bootstrap
  • vue
  • AngularJS
  • HBuilder教程
  • css3
  • 浏览器兼容
  • div/css
  • 网页编辑器
  • axure

最近更新的内容

    • angular ngClick阻止冒泡使用默认行为的方法
    • AngularJS使用angular-formly进行表单验证
    • 详解AngularJS的通信机制
    • AngularJS 中的事件详解
    • AngularJS基础 ng-mousemove 指令简单示例
    • AngularJS 单元测试(一)详解
    • AngularJS实现动态编译添加到dom中的方法
    • AngularJS基础学习笔记之表达式
    • 深入理解AngularJS中的ng-bind-html指令和$sce服务
    • 详解angular2采用自定义指令(Directive)方式加载jquery插件

关于我们 - 联系我们 - 免责声明 - 网站地图

©2020-2025 All Rights Reserved. linkedu.com 版权所有