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.
首先,在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
上面包含该行.我现在加入它是为了完整性.
对于现在正在寻找这个的人,从django-tables2 1.10开始,通过传递extra_columns
给Table
构造函数,动态地将列添加到表中.
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
归档时间: |
|
查看次数: |
4596 次 |
最近记录: |