如何使用 Dash 添加/创建自定义加载程序?

Dud*_*ude 2 python flask plotly plotly-dash plotly-python

我想将我的 gif 传递给加载器组件,而不是使用默认的数字。有人知道该怎么做吗?

这是我的代码:

dcc.Loading(
    id="loading-1",
    type="default",
    children=html.Div(id="loading-output-1"),
)
Run Code Online (Sandbox Code Playgroud)

我正在尝试完成这样的事情:

dcc.Loading(
    id="loading-1",
    type="assets/dashboard_loader.gif",
    children=html.Div(id="loading-output-1"),
)
Run Code Online (Sandbox Code Playgroud)

有人可以指导我吗?

Bas*_*den 9

type属性指定微调器的外观,但仅限于 dash 核心组件提供的一组值:

type(值等于:“graph”、“cube”、“circle”、“dot”、“default”;默认“default”):确定哪个微调器显示“graph”、“cube”之一的属性“圆”、“点”或“默认”。

所以你的方法目前是不可能的,但有一个解决方法。

默认微调器的 html 结构如下所示:

<div class="dash-spinner dash-default-spinner">
  <div class="dash-default-spinner-rect1"></div>
  <div class="dash-default-spinner-rect2"></div>
  <div class="dash-default-spinner-rect3"></div>
  <div class="dash-default-spinner-rect4"></div>
  <div class="dash-default-spinner-rect5"></div>
</div>
Run Code Online (Sandbox Code Playgroud)

里面的每个矩形 div 都.dash-spinner用于默认类型的动画。我们不关心这些矩形或 中的任何内容.dash-spinner,因为我们只想要 gif 动画。

所以我们在这里可以做的是隐藏所有.dash-spinner子项并添加动画背景.dash-spinner

我们可以用 css 来做到这一点

.dash-spinner {
  background-image: url("https://i.stack.imgur.com/SBv4T.gif");
  background-size: contain;
  background-repeat: no-repeat;
}

.dash-spinner * {
  display: none !important;
}
Run Code Online (Sandbox Code Playgroud)

要包含 CSS,请参阅此处的文档。

基于此处文档中给出的示例的最小且可重现的示例:

from dash import Dash
import time
import dash_core_components as dcc
import dash_html_components as html
from dash.dependencies import Input, Output


app = Dash(__name__)
app.layout = html.Div(
    children=[
        html.H3("Edit text input to see loading state"),
        dcc.Input(id="loading-input-1", value="Input triggers local spinner"),
        dcc.Loading(
            id="loading-1", type="default", children=html.Div(id="loading-output-1")
        ),
    ],
)


@app.callback(
    Output("loading-output-1", "children"),
    Input("loading-input-1", "value"),
    prevent_initial_call=True,
)
def input_triggers_spinner(value):
    time.sleep(2)
    return value


if __name__ == "__main__":
    app.run_server()
Run Code Online (Sandbox Code Playgroud)

Gif 取自此处的相关答案。