Skip to main content

简单的混合

ContextMixin

class django.views.generic.base.ContextMixin

方法

get_context_data(**kwargs)

返回表示模板上下文的字典。提供的关键字参数将构成返回的上下文。用法示例:

def get_context_data(self, **kwargs):
    context = super(RandomNumberView, self).get_context_data(**kwargs)
    context['number'] = random.randrange(1, 100)
    return context

所有基于类的通用视图的模板上下文包括指向 View 实例的 view 变量。

在适当的地方使用 alters_data

注意,在模板上下文中具有视图实例可能向模板作者暴露潜在的危险方法。为了防止在模板中调用这样的方法,请在这些方法上设置 alters_data=True。有关更多信息,请阅读 渲染模板上下文 的文档。

TemplateResponseMixin

class django.views.generic.base.TemplateResponseMixin

给定适当的上下文,提供一种构造 TemplateResponse 的机制。要使用的模板是可配置的,可以通过子类进一步自定义。

属性

template_name

要使用的字符串定义的模板的全名。不定义 template_name 会引发 django.core.exceptions.ImproperlyConfigured 异常。

template_engine

用于加载模板的模板引擎的 NAMEtemplate_engine 作为 using 关键字参数传递给 response_class。默认值是 None,它告诉Django在所有配置的引擎中搜索模板。

response_class

render_to_response 方法返回的响应类。默认值为 TemplateResponseTemplateResponse 实例的模板和上下文可以稍后改变(例如在 模板响应中间件 中)。

如果需要定制模板加载或自定义上下文对象实例化,请创建 TemplateResponse 子类并将其分配给 response_class

content_type

用于响应的内容类型。 content_type 作为关键字参数传递给 response_class。默认是 None - 这意味着Django使用 DEFAULT_CONTENT_TYPE

方法

render_to_response(context, **response_kwargs)

返回 self.response_class 实例。

如果提供了任何关键字参数,它们将被传递给响应类的构造函数。

调用 get_template_names() 以获取将要搜索的模板名称列表,查找现有模板。

get_template_names()

返回模板名称列表,以便在呈现模板时进行搜索。将使用找到的第一个模板。

如果指定了 template_name,则默认实现将返回包含 template_name 的列表(如果已指定)。