我使用 django-tables2 LinkColumn 创建一个列,该列调用一个允许导出表中对象的函数。
表格.py:
class FilesTable(tables.Table):
id = tables.LinkColumn('downloadFile', args=[A('pk')], verbose_name='Export')
我希望本专栏的内容是 downloadFile 函数的 href :导出为文本,而不是 id。
我使用 django-tables2 LinkColumn 创建一个列,该列调用一个允许导出表中对象的函数。
表格.py:
class FilesTable(tables.Table):
id = tables.LinkColumn('downloadFile', args=[A('pk')], verbose_name='Export')
我希望本专栏的内容是 downloadFile 函数的 href :导出为文本,而不是 id。
类似的东西应该可以工作(警告我这里没有 Python,所以它没有经过测试,但你会明白的):
类 CustomTextLinkColumn(LinkColumn): def __init__(self, viewname, urlconf=None, args=None, kwargs=None,current_app=None,attrs=None,custom_text=None,**额外): super(CustomTextLinkColumn, self).__init__(viewname, urlconf=urlconf, args=args,kwargs=kwargs,current_app=current_app,attrs=attrs,**额外) self.custom_text = custom_text def 渲染(自我,价值,记录,bound_column): return super(CustomTextLinkColumn, self).render(self, self.custom_text 如果 self.custom_text 其他值, 记录,bound_column)
然后你可以像这样使用它
id = CustomTextLinkColumn('downloadFile', args=[A('pk')], custom_text='出口',verbose_name='出口',)
当然,您始终可以使用 TemplateColumn 或向 FilesTable 添加 render_id 方法,但 CustomTextLinkColumn 绝对是最干燥的方法:)
我无法发表评论,所以我需要添加另一个答案。我将更正“渲染”调用在参数列表中不应包含“自我”。
class CustomTextLinkColumn(LinkColumn):
def __init__(self, viewname, urlconf=None, args=None,
kwargs=None, current_app=None, attrs=None, custom_text=None, **extra):
super(CustomTextLinkColumn, self).__init__(viewname, urlconf=urlconf,
args=args, kwargs=kwargs, current_app=current_app, attrs=attrs, **extra)
self.custom_text = custom_text
def render(self, value, record, bound_column):
return super(CustomTextLinkColumn, self).render(
self.custom_text if self.custom_text else value,
record, bound_column)
正如 Serafeim 所说,使用:
id = CustomTextLinkColumn('downloadFile', args=[A('pk')],
custom_text='Export', verbose_name='Export', )