我有一个Scrib
模型和一个将Scrib.objects.all()
存储到scribs
在模板中,我想访问模型的详细名称,如:
<h1>{{ scribs.model.verbose_name }}</h1>
是否可以或者我必须将Scrib
处理程序添加到上下文中?
答案 0 :(得分:10)
您无法直接从模板访问verbose_name。从我看到你有三个选择。
选项一(最简单)。在控制器中分配详细名称,然后从模板中访问它:
# in controller
render_to_response('template.html', {'scrib_verbose_name': Scrib._meta.verbose_name})
# in a view template.html
Verbose name of a Scrib model: {{ scrib_verbose_name }}
选项二:给自己写一个视图助手,它将返回给定类的verbose_name(或_meta类的其他字段)。
更新第三个选项(对Uku Loskit的提示) - 在scrib模型上定义一个方法,该方法返回元对象(或其中的任何特定字段)。
# method in a Scrib model
def meta(self):
return self._meta
# later on in a template - scrib is a instance of Scrib model
<h1>{{ scrib.meta.verbose_name }}</h1>
Update2 如果您坚持直接从scribs
访问详细名称(这是Scrib.objects.all()
的结果),那么您可以执行以下操作:
scribs = Scrib.objects.all()
scribs.verbose_name = Scrib._meta.verbose_name
# in a template you can now access verbose name from a scribs variable
{{ scribs.verbose_name }}
Update3 另一种方法是使用模型inhertinace能够从任何继承自我们自定义模型的模型的实例访问详细名称。
# base model (inherits from models.Model)
class CustomModel(models.Model):
def meta(self):
return self._meta
class Meta:
abstract = True
# Scrib now inherit from CustomModel
class Scrib(CustomModel):
# do any stuff you want here ...
Scrib现在继承自CustomModel,它为我们提供了属性 meta 。任何将从CustomModel类继承的模型都将具有此属性。这是最干净,最灵活的解决方案。
答案 1 :(得分:8)
我也想这样做,我想另一种解决方案是模板过滤器:
from django import template
register = template.Library()
@register.filter
def verbose_name(value):
return value._meta.verbose_name
@register.filter
def verbose_name_plural(value):
return value._meta.verbose_name_plural
然后在模板中:
1 {{ object|verbose_name }}, 2 {{ object|verbose_name_plural }}
1 scrib, 2 scribs
答案 2 :(得分:5)
除了WTK的建议,您可以在models.py
中为Scrib模型定义一个方法,如下所示:
def get_verbose_name(self):
return self._meta.verbose_name
# in templates
{{ scrib_instance.get_verbose_name }}