- Author:
- Voightkampff
- Posted:
- April 28, 2011
- Language:
- HTML/template
- Version:
- 1.3
- Score:
- 3 (after 6 ratings)
I was just playing around with Django 1.3 and came across the new 'with' addition to the include tag. I thought this was a super elegant way to implement a DRY tab menu without having to move menu code into the views. Enjoy!
1 2 3 4 5 6 7 8 9 10 11 12 13 | **Placed in templates/includes/tabs.html**
<ul class="tab-menu">
<li class="{% if active_tab == 'tab1' %} active{% endif %}"><a href="#">Tab 1</a></li>
<li class="{% if active_tab == 'tab2' %} active{% endif %}"><a href="#">Tab 2</a></li>
<li class="{% if active_tab == 'tab3' %} active{% endif %}"><a href="#">Tab 3</a></li>
</ul>
**Placed in your page template**
{% include "includes/tabs.html" with active_tab='tab1' %}
|
More like this
- Bootstrap Accordian by Netplay4 6 years ago
- Bootstrap theme for django-endless-pagination? by se210 9 years ago
- Bootstrap theme for django-endless-pagination? by se210 9 years ago
- Reusable form template with generic view by roldandvg 9 years, 1 month ago
- Pagination Django with Boostrap by guilegarcia 9 years, 3 months ago
Comments
Thanks for sharing. This was very helpful. Finally got my navigation working where it supports multiple/nested menu levels and shows which ones are active.
#
Thank you! When I created a snippet #2722 I did not take into account the option with of inclusion tag.
I think your solution is better.
My decision have only one plus (your have several ones). In case of #2722 inheritance is possible. Sometimes it is more convenient and conceptual than inclusion.
#
And one more plus in #2722. In your case if you want to mek whole fragment different (not only class attribute) you should write several times very similar code for each option. But I would like DRY menu.
#
Now I use your snippet instead of mine. Thanks a lot!
#
This is such a clean solution; thank you so much for taking the time to share this!
#
Thanks for this, I didn't know about
{% include with %}
. This is great!#
Please login first before commenting.