ホームページ > バックエンド開発 > Python チュートリアル > Django学習における静的ファイルの呼び出しについて詳しく解説

Django学習における静的ファイルの呼び出しについて詳しく解説

不言
リリース: 2018-05-08 13:44:03
オリジナル
1862 人が閲覧しました

この記事では主に、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 collectstatic
ログイン後にコピー

django はすべての静的ファイルを 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


この場合、ブラウザはエラーを報告します。そのようなページはありません

それでは、Django はどのようにしてブラウザがサーバー上の静的ファイルにアクセスできるようにするのでしょうか? 前に述べたように、ローカルに直接アクセスするのです。サーバーのアドレスは不可能なので、マッピングが必要です。Django は STATIC_URL を使用して、ブラウザーが次のような静的ファイルに直接アクセスできるようにします。次に、ブラウザーで次のように入力します。 192.168.1.2:8000/static/common_static/myapp/photo.png


そうすると、/home/mysite/common_static/myap/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 サイトの他の関連記事を参照してください。

関連ラベル:
ソース:php.cn
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート