2

フラスコアプリでscssとフラスコアセットを使用しています。

ここに私の app.py があります:

from flask_assets import Bundle, Environment
from flask import (Flask, render_template)
import os

app = Flask(__name__)
assets = Environment(app)
assets.url = app.static_url_path
assets.load_paths = [os.path.join(app.static_url_path, 'sass/abstracts')]
print(assets.load_paths)
assets.debug = True
app.debug = True



scss = Bundle('sass/abstracts/_variables.scss',
              'sass/base/_fu.scss',
              filters='pyscss', output='gen/all.css')

assets.register('scss_all', scss)

@app.route('/')
def home():
    return render_template('index.html')

if __name__ == "__main__":
    app.run(host='0.0.0.0')

load_paths を使用して、flask_assets に自分のファイルを探す場所を伝えています。私のプロジェクトの非常に基本的な構造は次のとおりです。

ファイル構造

私の all.css が生成されます。ただし、_fu.scss ファイル内の要約フォルダーから _variables.scss をインポートしようとすると。これが私が得るものです:

scss.errors.SassImportError
scss.errors.SassImportError: Couldn't find anything to import: _variables
Extensions: <NamespaceAdapterExtension>, <CoreExtension>, <ExtraExtension>, <FontsExtension>, <CompassExtension>, <BootstrapExtension>
Search path:
  /Users/davidgeismar/code/davidgeismar/quantiops/flask-assets-test/static/sass/base
  /Users/davidgeismar/anaconda3/lib/python3.6/site-packages/scss/sass/frameworks
on line 1 of /Users/davidgeismar/code/davidgeismar/quantiops/flask-assets-test/static/sass/base/_fu.scss

次に、変数ファイルを _fu.scss があるベース フォルダーに移動するとします。その後、動作します。

ここに私の _fu.scss ファイルがあります:

@import '_variables';
.tut {
  margin-top: 20px;
  color: $color-orange;
  background-color: $base-color;
}

ここで何が欠けていますか?

4

1 に答える 1

0

これは古い質問ですが、それでも試してみます...

関数にstatic_url_pathandstatic_folderを追加すれば問題は解決すると思いますか?app

    app = Flask(__name__,
                static_url_path='/',
                static_folder='../app/static')
于 2021-04-16T21:34:47.433 に答える