django 1.8.3
通常咱们在练习 django
渲染时,都须要使用 context
来解析渲染模板。
一般,context
是 django.template.Context
的实例,不过在 context
中还有一个特殊的子类, django.template.RequestContext
,这个和 context
稍微有些不一样。 RequestContext
默认地在模板 context
中添加一些变量html
使用 Contextdjango
from django.template import Context c = Context({ 'foo': 'bar', })
使用 RequestContextapp
RequestContext
使用 HttpRequest
做为第一个参数spa
from django.template import RequestContext c = RequestContext(request, { 'foo': 'bar', })
其实到这里,对于做者起了个 RequestContext
名字,鄙人有些不敢苟同,对于开发人员很容易形成误解,我的觉得应该为 WrapperContext
(纯属我的意见)debug
最熟悉的场景就是配置文件中设置的 context_processors
code
TEMPLATES = [ { 'BACKEND': 'django.template.backends.django.DjangoTemplates', 'DIRS': [os.path.join(os.path.dirname(os.path.abspath(__file__)), '../../templates/')], 'APP_DIRS': True, 'OPTIONS': { 'context_processors': [ 'django.contrib.auth.context_processors.auth', 'django.template.context_processors.debug', 'django.template.context_processors.request', 'django.template.context_processors.static', 'django.contrib.messages.context_processors.messages', ], }, }, ]
BaseView
中默认把 context_processors
指定的变量包装到 RequestContext
, 这时最多见的应用了,可是也有必定的弊端,就是全部的 View
中都会包含这些变量;htm
若是想避免这个坑,能够根据业务须要,本身自定义,这样哪里有需求,哪里就加载开发
from django.shortcuts import render_to_response from django.template import RequestContext def custom_proc(request): return { 'name': 'haha', 'sex': 'man' } def viewA(request): return render_to_response('tmpl1.html', {'name': 'viewA'}, context_instance=RequestContext(request, processors=[custom_proc])) def viewB(request): return render_to_response('tmpl2.html', {'name': 'viewB'}, context_instance=RequestContext(request, processors=[custom_proc]))
这样作也是有弊端,不方便使用 BaseView
, 还有若是重复次数太多,也不建议这样作模板
待续.....import