我需要显示几个型号的名称&模板中的对象
这是我的视图
def contents(request):
"""Lists contents"""
objects = [
Model1.objects.all(),
Model2.objects.all(),
Model3.objects.all(),
Model4.objects.all(),
]
return render_to_response('content/contents.html', objs
, context_instance=RequestContext(request)
)
我的模板
{% for objs in objects %}
<div class="content">
<div class="title">{{ objs._meta.verbose_name }}</div>
<ul>
{% for obj in objs %}
<li>{{ obj }}</li>
{% endfor %}
</ul>
</div>
{% endfor %}
当然objs._meta.verbose_name
不起作用
有没有办法访问这个详细的名称,而无需为每个模型创建一个函数或从每个模型的视图中分配值?
答案 0 :(得分:12)
为了在模板中访问它,您现在可能已经注意到Django不允许您使用下划线前缀来访问模板中的属性。因此,无需在每个模型上创建模型方法,访问任何给定对象的详细名称的最简单方法是创建模板标记:
@register.simple_tag
def get_verbose_name(object):
return object._meta.verbose_name
不相关,但您的模板中存在错误,因为您尝试访问查询集上的_meta属性而不是对象。所以你的标题行应该看起来像:
{% with objs|first as obj %}
<div class="title">{% get_verbose_name obj %}</div>
{% endwith %}
答案 1 :(得分:0)
标签:
@register.simple_tag
def get_verbose_name(object, fieldnm):
return object._meta.get_field(fieldnm).verbose_name
HTML(年份是我的模型中我的字段的名称)
<td><label class="control-label text-lg text-info"> {% get_verbose_name object 'year' %} </label></td>
感谢上面的参考。想分享我在其他情况下寻找与我的情况相同的解决方案的发现。
答案 2 :(得分:0)
另一种解决方案是将模型的QuerySet
子类化:
class SomeQuerySet(models.QuerySet):
@property
def verbose_name(self):
return self.model._meta.verbose_name
class SomeModel(models.Model):
...
objects = SomeQuerySet.as_manager()
class Meta:
verbose_name = 'Some Model'
现在,您可以直接从查询集中获取verbose_name
,而无需对其进行迭代:
<h1>{{ objects.verbose_name }}</h1>
{% for objs in objects %}
...
如果您想直接从模型实例而不是从verbose_name
访问QuerySet
,则还需要在模型中定义一个属性:
class SomeModel(models.Model):
...
objects = SomeQuerySet.as_manager()
class Meta:
verbose_name = 'Some Model'
@property
def verbose_name(self):
return self._meta.verbose_name
答案 3 :(得分:0)
在 Django 3.x 中,我发现这是最简单的方法。我通常将所有对象工具放在一个模块中:
from django import template
register = template.Library()
@register.filter
def verbose_name(obj):
return obj._meta.verbose_name
然后在模板中:
{{ object_name|verbose_name }}