I have this code
{% for account in object_list %}
{% for field, value in book.get_fields %}
{{ field.v
-
I think you should use slice to achieve your goal
{% for account in object_list|slice:":1" %}
讨论(0)
-
In this case you can check if forloop.counter == 1 or if forloop.first and simply print that first item.
{% for account in object_list %}
{% if forloop.first %}
<tr>
{% for field, value in book.get_fields %}
<th>{{ field.verbose_name }}</th>
{% endfor %}
</tr>
{% endif %}
{% endfor %}
讨论(0)
-
There is no break
in Django template system. Django template system is not programmed with python but with its own language.
Depending on what you need to do, you might find this question useful. Otherwise, just put the one and only account you are trying to print on HTML on a special field on your RequestContext
.
讨论(0)
-
You can use your Django template system for loop in javascript for loop as inner loop and can use break as follows :-
for(var i=0;i<1;i++){
{% for owner in Owner %}
id = "{{owner.id}}";
if(id == pk1){
f="{{owner.flat}}";
break;
}
{% endfor %}
}
讨论(0)
-
I found a way to do this with a condition. It's ugly and hacky, but it works (for me). first
is what the OP wanted, but this answers the actual question more closely.
Given this:
obj = {
'children': [
{ 'possessions' : { 'toys': [] } },
{ 'possessions' : { 'toys': ['train'] } }
{ 'possessions' : { 'toys': ['train', 'ball'] } }
]
}
I wanted to know if my obj has any children with possessions that are toys.
Here's what I did:
Python Equivalent:
if ([child for child in obj.children if child.possessions.toys]):
# Whatever
Django Template:
My approach was to use regroup to build sets of candidates which did or didn't match the criteria:
{% regroup obj.children by possessions.toys|length_is:"0" as by_toys %}
{% for check in by_toys %}{% if check.grouper == False %}
Whatever
{% endif %}{% endfor %}
regroup
builds a new object that is essentially:
[
{ 'grouper': '', 'list': [/*...*/] },
{ 'grouper': True, 'list': [/*...*/] },
{ 'grouper': False, 'list': [/*...*/] }
]
The length_is:"0"
makes sure that we have at most three elements in that list and the grouper
is either True
or False
or ''
. Then we iterate over the list and check for a False
value.
- If there are no children it'd be an empty list and the
if
would never be hit.
- If no children have toys, it'd be a list without a
False
grouper
.
- If all children have toys, it'd be a list with a
False
grouper
.
- If some children have toys, it'd be a list with
False
and True
grouper
s.
讨论(0)
-
You can't use break statement but you can choose not to print them on html. It's not a best solution but you can use it. I use the following one;
{%for tumbnail in image %}
{%if tumbnail.object_id == element.id %}
<img src="/media/{{ tumbnail.image }}" class="tr_all_hover"alt="">
{{ "<!--" }}
{%endif%}
{%endfor%}
{{ "-->" }}
Its basicly seem like this on browser.
http://i.stack.imgur.com/MPbR3.jpg
讨论(0)
- 热议问题