ホームページ >バックエンド開発 >Python チュートリアル >Django学習における静的ファイルの呼び出しについて詳しく解説
この記事では主に、Django 学習のための静的ファイルの呼び出しについて詳しく説明します。これは、必要な友人に参照してもらうために共有します。この記事では、主に Django の学習における静的ファイルの呼び出しに関する関連コンテンツを紹介します。以下ではあまり説明しません。
方法は以下の通りです
1.settings.py 静的ファイル関連のサンプルコードと手順:# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.8/howto/static-files/
STATIC_URL = '/static/'
# 当运行 python manage.py collectstatic 的时候
# STATIC_ROOT 文件夹 是用来将所有STATICFILES_DIRS中所有文件夹中的文件,以及各app中static中的文件都复制过来
# 把这些文件放到一起是为了用apache等部署的时候更方便
STATIC_ROOT = os.path.join(BASE_DIR, 'collected_static')
# 其它 存放静态文件的文件夹,可以用来存放项目中公用的静态文件,里面不能包含 STATIC_ROOT
# 如果不想用 STATICFILES_DIRS 可以不用,都放在 app 里的 static 中也可以
STATICFILES_DIRS = (
os.path.join(BASE_DIR, "common_static"),
'/path/to/others/static/', # 用不到的时候可以不写这一行
)
# 这个是默认设置,Django 默认会在 STATICFILES_DIRS中的文件夹 和 各app下的static文件夹中找文件
# 注意有先后顺序,找到了就不再继续找了
STATICFILES_FINDERS = (
"django.contrib.staticfiles.finders.FileSystemFinder",
"django.contrib.staticfiles.finders.AppDirectoriesFinder"
)
2.STATIC_ROOT
STATIC_ROOT = os.path.join(BASE_DIR, 'collect_static')#BASE_DIR是项目的绝对地址
STATIC_ROOT は静的ファイルをデプロイしています (pyhton manage.pycollectstatic) すべての静的静的集約ディレクトリを作成する場合、
STATIC_ROOT は絶対アドレスとして記述する必要があります。ここで、たとえば、私のプロジェクト mysite が /home/mysite/ である場合、STATIC_ROOT は次のようになります。 /home/mysite/collect_static/
プロジェクトをデプロイするときに、ターミナルに次のように入力します:python manage.py collectstaticdjango はすべての静的ファイルを STATIC_ROOT フォルダーにコピーします
3 STATICFILES_DIRS
STATIC_ROOT のみが機能します。デプロイメント中、実際には、静的ファイルの一般的な配置場所は 2 つあります: 1. 1 つは、静的ファイルを読み込むときに、各アプリに新しい静的フォルダーを作成し、その中に静的ファイルを配置することです。たとえば、To static files を使用すると、django は各アプリの静的フォルダーを自動的に検索します (そのため、間違ったフォルダー名を書かないでください。そうしないと、django がフォルダーを見つけることができなくなります2。別の方法:すべてのアプリ ファイルの外側にパブリック フォルダーを作成することです。一部の静的ファイルは特定のアプリに固有ではないため、管理を容易にするためにそれらをパブリック フォルダーに配置できます (パブリック フォルダーの作成は単に簡単です)。 -管理の練習ですが、その必要はありません。
app はアプリ間で静的ファイルを適用できます。最終的にはすべての静的ファイルが STATIC_ROOT に存在するためです) そこで問題となるのは、それをどのように作成するかです Django は、あなたが配置したことを知っています。いくつかの静的ファイルはアプリの外部のパブリックフォルダーにあるため、STATICFILES_DIRS を設定する必要がありますSTATICFILES_DIRS = ( os.path.join(BASE_DIR, 'common_static'), )
STATICFILES_DIRS は、最初に STATICFILES_DIRS で静的ファイルを探し、次にアプリの静的フォルダー内の各検索に移動するように django に指示します ( Django は遅延的な方法で静的ファイルを検索することに注意してください。最初のファイルが見つかると検索が停止します)
3.STATIC_URL
これまでのところ、静的ファイルのメカニズムは動作できますが、直接アクセスできるかという疑問があります。 URL 経由でプロジェクト内の静的ファイルにアクセスできますか? 答えは間違いなく「はい」ですが、ブラウザでアクセスしているため、静的ファイルのローカル絶対アドレス (たとえば、静的ファイルのローカル アドレス) を入力できないことに注意してください。私の写真は /home/mysite/common_static/myapp/photo.png です
http://192.168.1.2:8000/ home/mysite/common_static/ myapp/photo.png
この場合、ブラウザはエラーを報告します。そのようなページはありません
したがって、ブラウザでは、プレフィックスの特定のコンテンツを使用しますSTATIC_URL 、STATIC_ROOT をマップするには、
HTTP://192.168.1.2:8000/static は、ローカル アドレスの STATIC_ROOT に相当します
関連推奨事項:
Django の STATIC_ROOT、STATIC_URL、および STATICFILES_DIRS の簡単な分析
以上がDjango学習における静的ファイルの呼び出しについて詳しく解説の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。