3

我有一个多页破折号应用程序,在本地运行时可以按预期工作:

女服务员服务--listen=0.0.0.0:80 web_app.wsgi:application

因此资产文件夹中的所有资产都正确加载,图像加载src=app.get_asset_url('xyz.png')并设置app.css.config.serve_locallytrue,如此处所示,一切正常

但是当在 docker 容器中加载相同的应用程序时,资产不会加载而无法正常工作,因此本地 css 也不会加载。

已经检查了 docker 中的文件和文件夹,一切都符合预期。

我想我在某个地方遗漏了一些东西,但没有找到什么,关于如何让它工作的任何建议?

Dockerfile

FROM python:3

RUN apt-get update && apt-get install -qq -y \
build-essential libpq-dev --no-install-recommends

ENV INSTALL_PATH /gtg_analytics-master
ENV PYTHONPATH "${PYTHONPATH}:$INSTALL_PATH/web_app"
RUN mkdir -p $INSTALL_PATH

WORKDIR $INSTALL_PATH

COPY requirements.txt requirements.txt
RUN pip install -r requirements.txt

COPY web_app $INSTALL_PATH/web_app

码头工人撰写:

version: "3"

services:
web_app:
image: patber/gtg:dev
build: .
command: >
  waitress-serve --listen=0.0.0.0:80
  web_app.wsgi:application
environment:
  PYTHONUNBUFFERED: 'true'
volumes:
  - '.:/web_app'
ports:
  - '80:80'
4

3 回答 3

1

在这里找到了 CSS 文件的解决方案。

app.css.append_css({"external_url": "./assets/xyz.css"})
于 2019-03-20T15:54:29.540 回答
0

我遇到了同样的问题,这里提供的解决方案是正确的,但您还需要添加:

app.css.config.serve_locally = False

此外,您可以通过以下方式添加样式表,而不是附加:

external_stylesheets=["./assets/stylesheet.css"]
app = dash.Dash(__name__, external_stylesheets=external_stylesheets)
于 2019-12-05T15:29:51.570 回答
0

这不是很好,但是如果您需要提供除 css 以外的其他内容,您还可以使用外部源选项:

app = dash.Dash(
    __name__,
    assets_external_path='http://your-external-assets-folder-url/'
)

我用一张图片遇到了这个问题,这是我所知道的最好的(当前 = 20 年 1 月 30 日)解决方案。

于 2020-01-30T14:53:27.367 回答