Django | RequestContext 和 Context

版本

django 1.8.3

简述

通常咱们在练习 django 渲染时,都须要使用 context 来解析渲染模板。
一般,contextdjango.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_processorscode

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

相关文章
相关标签/搜索