我有一个从第二个模块导入layout的应用程序,然后在选项卡中呈现为返回此选项卡内容的app.layout。我有问题,布局是用输入的默认值导入的,当我用键填充输入并在选项卡之间切换时,当我点击回inputs选项卡时,值重置为默认值'x‘。我设法通过在回调中第二次声明布局来解决这个问题,但它看起来并不好,需要编写两次布局才能实现进一步的功能。下面是我的代码:
if 'manager' not in vars():
manager = Recognition('xx', 'xx')
print('defining manager')
lcheck = 0
while lcheck == 0:
layout = [
html.Div([
html.Div(
[
html.H3("Primary API key"),
dcc.Input(
id='primary-key',
value=manager.api_key,
placeholder='Enter a value...',
type='text',
style = {"width":"50%"}
),
html.H3("Private API key"),
dcc.Input(
id='private-key',
value=manager.api_secret,
placeholder='Enter a value...',
type='text',
style = {"width":"50%"}
),
],
),
html.Button('Submit', id='button', className='btn btn-primary'),
html.Div(id='output-hidden')
])
]
lcheck=1
@app.callback(
Output('primary-key', 'value'),
[Input('button', 'n_clicks')],
[State('primary-key', 'value'),
State('private-key', 'value')]
)
def update_output(n_clicks, value1, value2):
values = {'value1':value1, 'value2':value2}
global manager
global layout
manager.update(value1, value2)
layout = [
html.Div([
html.Div(
[
html.H3("Primary API key"),
dcc.Input(
id='primary-key',
value=manager.api_key,
placeholder='Enter a value...',
type='text',
style = {"width":"50%"}
),
html.H3("Private API key"),
dcc.Input(
id='private-key',
value=manager.api_secret,
placeholder='Enter a value...',
type='text',
style = {"width":"50%"}
),
],
),
html.Button('Submit', id='button', className='btn btn-primary'),
html.Div(id='output-hidden')
])
]
lcheck=0
return values['value1']正如你所看到的,每次我用按钮发送新的数据时,它都会保存新的布局,但这个解决方案看起来很糟糕,我想找到更好的解决方案,而不会在代码中出现混乱。整个过程就是更新布局变量中的value=manager.api_key,和value=manager.api_secret,。我正在考虑像从普通的list中访问这些值,但这是不可能的,因为它不是嵌套在常规列表中的。有没有办法访问这些值,例如layout.getid("primary-key").value或类似的东西?如何清理这段代码?
发布于 2018-11-28 19:21:23
我已经想出了解决这个问题的办法。因为我的应用程序在每次选择选项卡时都会渲染app.layout,所以它总是渲染第一次导入时分配的layout。首先,我想每次都在回调函数中覆盖布局,但是编写两次layout=是没有意义的。所以我在dash docs中找到了一个名为dcc.Store的dash core component (它将json存储在隐藏的div中)。我是这样使用的:
html.Div([
dcc.Store(id='storage')
],
id="hiddendata",
style={"display": "none"},
),这个div直接放在' tabs‘div后面,作为一个’缓存‘内存,供标签记住之前的状态。最后,每次我发送新的键时,我都会更新回调来更改dcc.Store中的数据,这样当我离开选项卡时,其他选项卡就会知道那里有什么:
@app.callback(
Output('storage', 'data'),
[Input('button', 'n_clicks')],
[State('primary-key', 'value'),
State('private-key', 'value')]
)
def update_output(n_clicks, value1, value2):
values = {'value1':value1, 'value2':value2}
global manager
global layout
manager.update(value1, value2)
lcheck=0
return values
@app.callback(
Output('primary-key', 'value'),
[Input('storage', 'data')],
[State('storage', 'data')])
def update_values(values, value):
if values:
return value['value1']
@app.callback(
Output('private-key', 'value'),
[Input('storage', 'data')],
[State('storage', 'data')])
def update_values(values, value):
if values:
return value['value2']https://stackoverflow.com/questions/53498916
复制相似问题