在Dash框架中动态添加HTML输入

时间:2018-06-21 06:28:50

标签: python html5 python-2.7 dynamic plotly-dash

我是Dash的新手,我需要一些帮助。我需要创建动态数量的输入,但是我不知道如何为每个滑块组件绑定动态数量的回调。我只能创建动态数量的滑块,但是正如您在代码中看到的那样,我需要对回调的数量进行硬编码。是否有更好的方法可以使它更具动态性?

@app.callback(
    Output('slider-container', 'children'),
    [Input('button', 'n_clicks')])
def add_sliders(n_clicks):
    return \
        html.Div([
            html.Div([
                html.Div(dcc.Slider(id='slider-{}'.format(i))),
                dcc.Input(
                    id='input-{}'.format(i),
                    placeholder='Graph Name',
                    type='text',
                    value=''
                ),
                html.Div(id='output-{}'.format(i), style={'marginTop': 30})
            ]) for i in range(n_clicks)]
        )


# up to 10 sliders
for i in range(10):
    @app.callback(
        Output('slider-{}'.format(i), 'children'),
        [Input('slider-{}'.format(i), 'value'),
        Input('input-{}'.format(i), 'value')])
    def update_output(slider_i_value, input_i_value):
        return str(slider_i_value) + str(input_i_value)

1 个答案:

答案 0 :(得分:1)

从 Dash 1.11.0 开始,您有 Pattern Matching Callbacks 可以做到这一点。在您的情况下,您将使用带有 MATCH 的那个。