首页 > 解决方案 > 无法使 Datatable 响应 -Bokeh

问题描述

我试图通过将 sizing_mode 属性设置为 "stretch_both" 来使散景数据表响应。但与其他模型不同,它不使用 datatable.width 数据表显示为固定

data_table = DataTable(
    source=sourceDT,
    columns=columns,
    height=200,
fit_columns=True,
    editable=False,
    index_position=None,name="DT"
)
data_table.sizing_mode = "scale_width"

我怎样才能使这个响应。有人请

标签: datatableresponsivebokeh

解决方案


不幸的是 对sizing_mode没有影响DataTable。一种解决方法是动态设置表格宽度的滑块(Bokeh v1.0.4)。

from bokeh.io import show
from bokeh.layouts import widgetbox
from bokeh.models import ColumnDataSource, Slider, DataTable, TableColumn, CustomJS

source = ColumnDataSource(dict(x = list(range(6)), y = [x ** 2 for x in range(6)]))
columns = [TableColumn(field = "x", title = "x"), TableColumn(field = "y", title = "x**2")]
table = DataTable(source = source, columns = columns, width = 320)
slider = Slider(start = 1, end = 100, value = 6, step = 1, title = "i", width = 300)
callback_code = """ i = slider.value;
                    new_data = {"x": [1, 2, 3, 4, 5], "y": [1, 4, 9, 16, 25]}
                    table.source.data = new_data
                    table.width = 320 + i * 25;  """
callback = CustomJS(args = dict(slider = slider, table = table), code = callback_code)
slider.js_on_change('value', callback)
show(widgetbox(slider, table))

在此处输入图像描述


推荐阅读