Вот «почти» рабочий пример того, что я хочу сделать с Dash.Почти потому, что этот код работает, но отсутствует часть того, что я намереваюсь сделать, но когда я пытаюсь реализовать эту другую часть, я получаю ошибку.
import dash
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output
app = dash.Dash()
app.config['suppress_callback_exceptions']=True
image = "tmpimg.png"
app.layout = html.Div([
html.Div([
html.Div([
html.Button('Load image', id='load-button'),
dcc.Upload(
id='upload-data',
children=html.Button('Upload image', id='upload-button')
)
]),
html.Div([
html.Div(id='images-div'),
html.Div(id='classification-div'),
html.Div(id='classification-div2')
])
])
])
@app.callback(
Output(component_id='images-div', component_property='children'),
[Input('load-button','n_clicks')]
)
def update_output_div_img(n_clicks):
return html.Div([html.Img(
src=app.get_asset_url(image),
style={
'width' : '10%',
'cursor': 'pointer'
}
)], id='img'
)
@app.callback(
Output(component_id='classification-div', component_property='children'),
[Input('img','n_clicks')]
)
def update_output_div1(n_clicks):
return html.Div([html.H2('Div1')])
@app.callback(Output('classification-div2', 'children'),
[Input('upload-data', 'contents')])
def update_output_div2(content):
return html.Div([html.H2('Div2')])
@app.callback(
Output(component_id='classification-div', component_property='style'),
[Input('upload-data', 'contents')]
)
def update_style(content):
if content:
return {'display':'none'}
else: return {'display':'inline'}
if __name__ == '__main__':
app.run_server()
update_output_div_img загрузит изображение с обратным вызовом, когда вызагрузить страницу или при нажатии на кнопку «Загрузить изображение».Теперь после загрузки изображения вы можете щелкнуть по нему, и появится текст Div1.Когда вы нажимаете кнопку загрузки для загрузки изображения, «Div1» должен исчезнуть, и остается только Div 2.Пока все хорошо.
Теперь, когда я снова нажимаю на изображение, текст «Div1» не появляется, потому что дисплей был изменен на «нет».Я хочу, чтобы при повторном нажатии на изображение снова отображался текст «Div1», поэтому я изменил функцию обратного вызова для стиля первого элемента div, описанного выше, таким образом, чтобы он срабатывал при нажатии на изображение, и посколькусодержание, я думаю, должно изменить отображение на встроенное.
@app.callback(
Output(component_id='classification-div', component_property='style'),
[Input('upload-data', 'contents'),
Input('img','n_clicks')]
)
def update_style(content,n_clicks):
if content:
return {'display':'none'}
else: return {'display':'inline'}
Но это вызывает сообщение «Ошибка загрузки зависимостей» при загрузке веб-страницы.Я думаю, что проблема возникает, потому что изображение, по которому щелкают, генерируется другим обратным вызовом, в то время как компонент загрузки был загружен с самого начала.
Есть идеи, как обойти это?