1

一般的なDjangoプロジェクトの構造について詳しく読んだ後、「media」フォルダーの名前を「static」に変更しました。これは、WebアプリのCSS、javascript、および画像が含まれており、ユーザーがアップロードしたファイルがないためです。ただし、私のプロジェクトは新しいディレクトリを見つけられず、ファビコンは引き続き提供されており、localhost:8000 /media/images/favicon.pngの古いディレクトリからダウンロードできます

私のテンプレートでは、次のようにcss/jsファイルに直接リンクしています。

<link href="/static/css/map.css" type="text/css" rel="stylesheet" />

また、urls.pyでは何も面白いことが起こっていません:

urlpatterns = patterns('',

    url(r'^$', 'EventMapperApp.views.map', name='map'),

    # AJAX
    url(r'^all_events/', 'EventMapperApp.views.all_events'),
    url(r'^user_created_events/', 'EventMapperApp.views.user_created_events'),
    url(r'^all_user_events/', 'EventMapperApp.views.all_user_events'),

    # event actions
    url(r'^save_event/', 'EventMapperApp.views.save_event'),
    url(r'^unsave_event/', 'EventMapperApp.views.unsave_event'),
)

何か案は?


編集


何らかの理由で、urls.pyがDjangoアプリのすべてのURLを解決する必要はないと思いましたか?何を考えているのかよくわかりません...とにかく、ドキュメントに従ってコードに適切な変更を加えましたが、それでも機能させるのに問題があります。

settings.py

PROJECT_PATH = os.path.dirname(os.path.abspath(__file__))

# Absolute filesystem path to the directory that will hold user-uploaded files.
# Example: "/var/www/example.com/media/"
MEDIA_ROOT = (os.path.join(PROJECT_PATH, "media"))

# URL that handles the media served from MEDIA_ROOT. Make sure to use a
# trailing slash.
# Examples: "http://example.com/media/", "http://media.example.com/"
MEDIA_URL = '/media/'

# Absolute path to the directory static files should be collected to.
# Don't put anything in this directory yourself; store your static files
# in apps' "static/" subdirectories and in STATICFILES_DIRS.
# Example: "/var/www/example.com/static/"
STATIC_ROOT = (os.path.join(PROJECT_PATH, "static"))

# URL prefix for static files.
# Example: "http://example.com/static/", "http://static.example.com/"
STATIC_URL = '/static/'

urls.py

urlpatterns = patterns('',
    # Examples:
    url(r'^$', 'EventMapperApp.views.map', name='map'),

    # Required to make static serving work
    (r'^static/(?P<path>.*)$', 'django.views.static.serve', {'document_root': settings.STATIC_ROOT}),

    # AJAX
    url(r'^all_events/', 'EventMapperApp.views.all_events'),
    url(r'^user_created_events/', 'EventMapperApp.views.user_created_events'),
    url(r'^all_user_events/', 'EventMapperApp.views.all_user_events'),

    # event actions
    url(r'^save_event/', 'EventMapperApp.views.save_event'),
    url(r'^unsave_event/', 'EventMapperApp.views.unsave_event'),
)

レンプレート

<link rel="icon"
      type="image/png"
      href="{{ STATIC_URL }}images/WWWfavicon.png" />
<link href="{{ STATIC_URL }}css/map.css" type="text/css" rel="stylesheet" />
<link href="{{ STATIC_URL }}css/ui-lightness/jquery-ui-1.8.21.custom.css" type="text/css" rel="stylesheet" />
<link href="{{ STATIC_URL }}css/timepicker.css" type="text/css" rel="stylesheet" />

私が今何を間違っているのかわかりません...STATIC_ROOTコードをウォークスルーすると、正しく解決されているようです(「static」フォルダーはsettings.pyと同じディレクトリにあります)。


編集2


https://docs.djangoproject.com/en/dev/howto/static-files/#serving-static-files-in-developmentに従って、 urls.pyを次のように変更しました。

from django.conf.urls import patterns, url
from django.conf import settings
from django.contrib.staticfiles.urls import staticfiles_urlpatterns

urlpatterns = patterns('',
    # Examples:
    url(r'^$', 'EventMapperApp.views.map', name='map'),

    # AJAX
    url(r'^all_events/', 'EventMapperApp.views.all_events'),
    url(r'^user_created_events/', 'EventMapperApp.views.user_created_events'),
    url(r'^all_user_events/', 'EventMapperApp.views.all_user_events'),

    # event actions
    url(r'^save_event/', 'EventMapperApp.views.save_event'),
    url(r'^unsave_event/', 'EventMapperApp.views.unsave_event'),
)

# only in development
urlpatterns += staticfiles_urlpatterns()

まだ運がない。

4

1 に答える 1

0

ここを参照してください: テンプレート内の静的ファイルと開発 中の静的ファイルの提供

于 2012-07-23T21:01:54.413 に答える