Django-tables2 - 动态地向表添加列 - 不在html中向表标记添加attrs

cop*_*tte 8 python django django-tables2

在我的Django项目中,我需要有表,哪些列是动态的,并且取决于数据库中的内容.所以我在这里找到了一个解决方案,它有效,但有一点问题.这是我正在动态扩展的表的类:

class ClientsTable(tables.Table):
    class Meta:
        model = Client
        attrs = {"class": "paleblue", "orderable":"True", "width":"100%"}
        fields = ('name',)

    def __init__(self, *args, **kwargs):
        super(ClientsTable, self).__init__(*args, **kwargs)
        self.counter = itertools.count()

    def render_row_number(self):
        return '%d' % next(self.counter)

    def render_id(self, value):
        return '%s' % value
Run Code Online (Sandbox Code Playgroud)

这是扩展类的方法:

def define_table(roles):
    attrs = dict((r.name, tables.Column() for r in roles)
    klass = type('DynamicTable', (ClientsTable,), attrs)
    return klass
Run Code Online (Sandbox Code Playgroud)

当我在views.py中创建一个像这样的表:

table = define_table(roles)(queryset)
Run Code Online (Sandbox Code Playgroud)

该表显示了我想要的列,但在html代码中,我看到它忽略了attrs:

{"class": "paleblue", "orderable":"True", "width":"100%"}
Run Code Online (Sandbox Code Playgroud)

所以paleblue没有css风格,这对我很重要.我觉得它可能是Meta类的东西但是字段和模型正在工作,所以我不知道为什么没有attrs.

Ser*_*eim 7

首先,在django-tables2 中不继承元选项.因此,您可以检查问题中讨论的变通方法,看看是否适合,或者您可以手动将Meta类添加到动态表中.要做到这一点,你可以使用这样的define_table方法:

def define_table(roles):
  attrs = dict((r.name, tables.Column() for r in roles)
  attrs['Meta'] = type('Meta', (), dict(attrs={"class":"paleblue", "orderable":"True", "width":"100%"}) )
  return klass

经过两年多的哎呀,我注意到我的代码中有错误 - 我忘记klass = type('DynamicTable', (ClientsTable,), attrs)return klass上面包含该行.我现在加入它是为了完整性.


Ali*_*ton 6

对于现在正在寻找这个的人,从django-tables2 1.10开始,通过传递extra_columnsTable构造函数,动态地将列添加到表中.

extra_columns应该是元组列表,定义列名和Column对象,例如.

class MyTable(Table):
    static_column = Column()

mytable = MyTable(extra_columns=[('dynamic_column', Column())]
Run Code Online (Sandbox Code Playgroud)

请参阅API文档:http://django-tables2.readthedocs.io/en/latest/pages/api-reference.html#django_tables2.tables.Table