「AngularJS x Django」の版間の差分
ナビゲーションに移動
検索に移動
1行目: | 1行目: | ||
==AngularJS x Django== | ==AngularJS x Django== | ||
− | [[AngularJS]][[Django]] | + | | [[AngularJS]] | [[Django]] |
===テンプレートの共存させたい=== | ===テンプレートの共存させたい=== |
2020年2月15日 (土) 08:30時点における版
AngularJS x Django
| AngularJS | Django
テンプレートの共存させたい
- Djangoのテンプレートと、AngularJSのテンプレートを共存させたい
- テンプレートタグの衝突
- {% verbatim %} ~ {% endverbatim % } の間は Djangoテンプレートの展開は無効になる
<!DOCTYPE html> <html ng-app> <head> <meta charset="UTF-8"> <title>PhraseIt.info</title> </head> <body> {% csrf_token %} {% verbatim %} <h1>テンプレート:'PhraseIt.info'</h1> {% endverbatim %} {% if DEBUG %} <script type="text/javascript" src="テンプレート:STATIC URLjs/angularjs/1.3.15/angular.min.js"></script> {% else %} <script type="text/javascript" src="https://ajax.googleapis.com/ajax/libs/angularjs/1.3.15/angular.min.js"></script> {% endif %} </body> </html>
- crsfトークンの利用
- {% csrf_token %} を設定したうえで、DjangoのCSRFトークンを送信するようにconfigで設定する
- https://docs.angularjs.org/api/ng/provider/$httpProvider
- http://django-docs-ja.readthedocs.org/en/latest/ref/contrib/csrf.html
app.config(['$httpProvider', function ($httpProvider) { $httpProvider.defaults.xsrfHeaderName = 'X-CSRFToken'; $httpProvider.defaults.xsrfCookieName = 'csrftoken'; }]);
© 2006 矢木浩人