2024-04-29 16:19:29 发布
网友
我使用django-tables2在模板的表中呈现数据。。 通过分页,一切都变得很好。。在
我们公司的设计师想把数据的显示改成块,而不是简单的表。下面的图片可以解释更多。在
我想问一下在这种情况下是否可以使用Django tables2,因为我不想失去分页
是否可以自定义django_tables2/table.html文件以仅适合这种情况(因为我在项目的许多其他页面中使用django-tables2)?在
django_tables2/table.html
任何其他的想法都可能有帮助。在
提前感谢:)
我也有同样的要求,我也能做到。为了获得所需的结果,我使用了bootstrap4并修改了“django_tables2/bootstrap4.html”模板。我修改过的模板只显示可以通过在其中嵌入更多css来进一步增强的块。在
{% load django_tables2 %} {% load i18n %} {% block table-wrapper %} <div class="container-fluid relative animatedParent animateOnce p-0" > {% block table %} {% block table.tbody %} <div class="row no-gutters"> <div class="col-md-12"> <div class="pl-3 pr-3 my-3"> <div class="row"> {% for row in table.paginated_rows %} {% block table.tbody.row %} <div class="col-md-6 col-lg-3 my-3"> <div class="card r-0 no-b shadow2"> {% for column, cell in row.items %} <div class="d-flex align-items-center justify-content-between"> <div class="card-body text-center p-5"> {% if column.localize == None %}{{ cell }}{% else %}{% if column.localize %}{{ cell|localize }}{% else %}{{ cell|unlocalize }}{% endif %}{% endif %} </div> </div> {% endfor %} </div> </div> {% endblock table.tbody.row %} {% empty %} {% if table.empty_text %} {% block table.tbody.empty_text %} <tr><td colspan="{{ table.columns|length }}">{{ table.empty_text }}</td></tr> {% endblock table.tbody.empty_text %} {% endif %} {% endfor %} </div></div></div> </div> {% endblock table.tbody %} {% block table.tfoot %} {% if table.has_footer %} <tfoot {{ table.attrs.tfoot.as_html }}> <tr> {% for column in table.columns %} <td {{ column.attrs.tf.as_html }}>{{ column.footer }}</td> {% endfor %} </tr> </tfoot> {% endif %} {% endblock table.tfoot %} {% endblock table %} </div> {% block pagination %} {% if table.page and table.paginator.num_pages > 1 %} <nav aria-label="Table navigation"> <ul class="pagination justify-content-center"> {% if table.page.has_previous %} {% block pagination.previous %} <li class="previous page-item"> <a href="{% querystring table.prefixed_page_field=table.page.previous_page_number %}" class="page-link"> <span aria-hidden="true">«</span> {% trans 'previous' %} </a> </li> {% endblock pagination.previous %} {% endif %} {% if table.page.has_previous or table.page.has_next %} {% block pagination.range %} {% for p in table.page|table_page_range:table.paginator %} <li class="page-item{% if table.page.number == p %} active{% endif %}"> <a class="page-link" {% if p != '...' %}href="{% querystring table.prefixed_page_field=p %}"{% endif %}> {{ p }} </a> </li> {% endfor %} {% endblock pagination.range %} {% endif %} {% if table.page.has_next %} {% block pagination.next %} <li class="next page-item"> <a href="{% querystring table.prefixed_page_field=table.page.next_page_number %}" class="page-link"> {% trans 'next' %} <span aria-hidden="true">»</span> </a> </li> {% endblock pagination.next %} {% endif %} </ul> </nav> {% endif %} {% endblock pagination %} {% endblock table-wrapper %}
是的,您可以创建一个自定义模板(基于^{}),并将特定表的template Meta属性设置为其路径:
import django_tables2 as tables class Table(tables.Table): # columns class Meta: template = 'table-blocks.html'
或者对Table构造函数使用template参数:
Table
template
或者使用{% render_table %}templatetag的第二个参数:
{% render_table %}
我也有同样的要求,我也能做到。为了获得所需的结果,我使用了bootstrap4并修改了“django_tables2/bootstrap4.html”模板。我修改过的模板只显示可以通过在其中嵌入更多css来进一步增强的块。在
是的,您可以创建一个自定义模板(基于^{} ),并将特定表的template Meta属性设置为其路径:
或者对
^{pr2}$Table
构造函数使用template
参数:或者使用
^{3}${% render_table %}
templatetag的第二个参数:相关问题 更多 >
编程相关推荐