Ste*_*mer 5 python twitter-bootstrap plotly-dash
我在下面有一个plotly dash应用程序的工作示例,它在选项卡上显示一个下拉列表,然后在选择下拉列表中的一个项目时显示一个警报。
#!/usr/bin/env python3
import dash
import dash_bootstrap_components as dbc
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output
app = dash.Dash('Example', external_stylesheets=[dbc.themes.DARKLY])
app.title = 'Example'
app.layout = dbc.Tabs([
dbc.Tab(
dbc.Card([
dcc.Dropdown(id='dropdown',
options=[
{ 'label': 'Item 1', 'value': 'foo' },
{ 'label': 'Item 2', 'value': 'bar' },
],
),
html.Br(),
html.Div(id='item-display'),
], body=True), label='Tab 1')
])
@app.callback(
Output('item-display', 'children'),
[Input('dropdown', 'value')]
)
def display_item(v):
return dbc.Alert(f'You selected Item {value}', color='primary') if v else ''
if __name__ == '__main__':
app.run_server(debug=True)
Run Code Online (Sandbox Code Playgroud)
我正在使用bootswatch 黑暗主题。
我遇到的问题是我不知道如何dash_core_components.Dropdown使用 bootstrap 样式设置样式。
如下图所示,dash_bootstrap_components所有元素都根据引导程序样式设置样式,但Dropdown事实并非如此,实际上下拉时的文本几乎无法阅读,因为它是非常浅的背景上的白色文本。
在深色样本中,下拉列表如下所示:
将鼠标悬停在选项上时,背景是引导程序的“主要”颜色:
如何dcc.Dropdown根据引导程序样式设置样式?
我注意到您也在 Plotly 论坛上提出了这个问题,特别是,其中一个答案中链接的答案可能包含一个有用的起点。我自己做的是对此答案的轻微修改:添加assets/dropdown.css包含以下内容的:
.Select-control {
background-color: #222 !important;
}
.Select.is-focused > .Select-control {
background-color: #222;
}
#school-input {
color: white;
}
.Select-value-label {
color: white;
}
.Select--single > .Select-control .Select-value, .Select-placeholder {
border: 1px solid grey;
border-radius: 4px;
}
.VirtualizedSelectOption {
background-color: #222;
color: white;
}
.VirtualizedSelectFocusedOption {
background-color: #222;
opacity: .7;
}
.Select.is-focused:not(.is-open) > .Select-control {
background-color: #222;
border-color: var(--primary);
box-shadow: none;
}
Run Code Online (Sandbox Code Playgroud)