2

我正在使用 django 1.5.2,我很难理解媒体目录与静态目录的用途以及如何在我的 django 项目中包含样式表。

这是我的目录结构:

django_books
    beer
        __init__.py
        admin.py
        models.py
        views.py
    random_book
        (same as beer above)
    django_books (the actual django project; beer and random_book above are my apps)
        templates
            base.html
            beersall.html
        __init__.py
        settings.py
        urls.py
        views.py
        wsgi.py
        static
            css
                beers.css
    media
        css
            beers.css
    static
        css
            beers.css
    manage.py

我的 beersall.html 模板(啤酒输出是正确的,所以只是链接样式表是错误的):

{% extends 'base.html' %}
{% block content %}

    <div id="beer_list">
        {% for beer in beers %}
        {{ beer }},
        {% endfor %}
    </div>

{% endblock %}

我的 base.html 文件:

<html>
<head>

    <link rel="stylesheet" type="text/css" href="/media/css/beers.css" />
    <link rel="stylesheet" type="text/css" href="{{ STATIC_URL }}css/beers.css" />
    <link rel="stylesheet" type="text/css" href="{{ MEDIA_URL }}css/beers.css" />
    <link rel="stylesheet" type="text/css" href="/static/css/beers.css" />
    <link rel="stylesheet" type="text/css" href="/Users/username/Projects/django_books/media/beers.css" />
    <link rel="stylesheet" type="text/css" href="/Users/username/Projects/django_books/static/beers.css" />
    <link rel="stylesheet" type="text/css" href="/Users/username/Projects/django_books/django_books/static/beers.css" />

    {% block extrahead %}{% endblock %}
</head>
<body>
    <div id="page_container">
        {% block content %}
        {% endblock %}
    </div>
</body>
</html>

我的 settings.py 文件:

MEDIA_ROOT = '/Users/username/Projects/django_books/media/'
MEDIA_URL = '/Users/username/Projects/django_books/media/'
STATIC_ROOT = ''
STATIC_URL = '/static/'

我应该注意我使用的是 django 开发服务器,而不是 apache。

我的浏览器(开发人员控制台)中的错误beers.css是 404。

url 是localhost:8000/beers/,我的 urls.py 文件正确指向这个,views.py 正确地为 beersall.html 模板提供服务。如何正确链接我的媒体?

编辑

当我将css链接href值更改为/Users/username/Projects/django_books/media/它仍然不起作用。

编辑 2

我已经更新了href值以显示我尝试过的东西。还是行不通...

4

3 回答 3

0

用户上传的文件(由管理员或站点用户)转到媒体目录。静态文件是开发人员(或第三方应用程序)提供的文件。

设置如下:

# Local disk paths
MEDIA_ROOT = '/Users/username/Projects/django_books/media/'
STATIC_ROOT = '/Users/username/Projects/django_books/static/'

# URLs visible in the browser's address bar
MEDIA_URL = '/media/'
STATIC_URL = '/static/'

在您的模板中使用STATIC_URL变量:

<link rel="stylesheet" type="text/css" href="{{ STATIC_URL }}css/beers.css" />

并将您的样式移动到django_books/static/目录中。

于 2013-08-28T23:22:58.657 回答
0

在我的项目中:django_learn,在模板中:check_uncheck_all.html,代码的一部分:

{% load staticfiles %}
<html>
    <head>
        <script type=text/javascript src="{% static 'js/jquery-1.9.1.js' %}"></script>
    </head>

你也可以看看我的 settings.py

于 2013-09-04T14:13:57.757 回答
0

找到了静态文件,但权限设置不正确。(即 403 不是 404 服务器错误)

<VirtualHost *:80>

    WSGIScriptAlias / /Users/username/Projects/django_books/django_books/django.wsgi

    #the directory tag before was /Users/username/Projects/django_books/django_books/>
    #this was one directory too deep
    #from my structure above, you can see I needed to change my directory tag to this:

    <Directory /Users/username/Projects/django_books/>
        Order Allow,Deny
        Allow from All
    </Directory>

    <Directory /Users/username/.virtualenvs/django_books/lib/python2.7/site-packages/django/contrib/admin/static/admin/>
        Order Allow,Deny
        Allow from All
    </Directory>

    Alias /static/admin/ /Users/username/.virtualenvs/django_books/lib/python2.7/site-packages/d$
    Alias /static/ /Users/username/Projects/django_books/static/

</VirtualHost>
于 2013-09-05T00:24:10.150 回答