Le serveur a renvoyé TemplateSyntaxError at / Invalid block tag: 'static'
sur cette ligne: <img src="{% static 'icon/logo.png' %}">
.
Le fichier html complet est comme ceci (c'est un fichier html {% include%} édité par un autre):
{% load staticfiles %}
<div class="header">
<nav>
<ul class="nav nav-pills pull-right">
<li role="presentation"><a href="{% url 'offer rank' %}">潮品榜</a></li>
<li role="presentation"><a href="{% url 'user rank' %}">达人榜</a></li>
<li role="presentation"><a href="#" data-toggle="modal" data-target="#start">登陆</a></li>
<li role="presentation"><a href="#" data-toggle="modal" data-target="#start">注册</a></li>
{% if debug_users %}
<li class="dropdown">
<a href="#" class="dropdown-toggle" data-toggle="dropdown" role="button" aria-expanded="false">切换用户<span class="caret"></span></a>
<ul class="dropdown-menu" role="menu">
{% for debug_user in debug_users %}
<li><a href="{% url 'debug login' debug_user.id %}">{% if debug_user.kbjuser.user_type == '1' %}达人{% else %}商家{% endif %}: {{ debug_user.username }}</a></li>
{% endfor %}
</ul>
</li>
{% endif %}
</ul>
</nav>
<h3><img src="{% static 'icon/logo.png' %}">
<a href="{% url 'home' %}" class="text-muted">口碑街</a>
</h3>
</div>
Et settings.py est comme ceci:
# Static files (CSS, JavaScript, Images)
# https://docs.djangoproject.com/en/1.7/howto/static-files/
STATIC_URL = '/static/'
STATIC_ROOT = os.path.join(BASE_DIR, "static/")
MEDIA_URL = '/media/'
MEDIA_ROOT = os.path.join(BASE_DIR, "media/")
from hw.settings import *
from useraccess.settings import *
STATICFILES_FINDERS = (
'Django.contrib.staticfiles.finders.FileSystemFinder',
'Django.contrib.staticfiles.finders.AppDirectoriesFinder',
# other finders..
'compressor.finders.CompressorFinder',
)
COMPRESS_ENABLED = True
Je ne peux pas comprendre ce qui se passe ici.
Voici quelques lignes supplémentaires dans settings.py:
# Application definition
INSTALLED_APPS = (
'Django.contrib.admin',
'Django.contrib.auth',
'Django.contrib.contenttypes',
'Django.contrib.sessions',
'Django.contrib.messages',
'Django.contrib.staticfiles',
'mptt',
'hw',
'useraccess',
'proxy',
'compressor',
'sekizai',
)
MIDDLEWARE_CLASSES = (
'Django.contrib.sessions.middleware.SessionMiddleware',
'Django.middleware.common.CommonMiddleware',
'Django.middleware.csrf.CsrfViewMiddleware',
'Django.contrib.auth.middleware.AuthenticationMiddleware',
'Django.contrib.auth.middleware.SessionAuthenticationMiddleware',
'Django.contrib.messages.middleware.MessageMiddleware',
'useraccess.middleware.VisitCollectMiddleware',
'Django.middleware.clickjacking.XFrameOptionsMiddleware',
)
TEMPLATE_CONTEXT_PROCESSORS = (
'Django.contrib.auth.context_processors.auth',
'Django.core.context_processors.i18n',
'Django.core.context_processors.request',
'Django.core.context_processors.media',
'Django.core.context_processors.static',
'hw.context_processors.user_info',
'hw.context_processors.login_form',
'hw.context_processors.get_all_user',
'sekizai.context_processors.sekizai',
)
ROOT_URLCONF = 'ddw.urls'
WSGI_APPLICATION = 'ddw.wsgi.application'
LOGIN_URL = '/login/'
Assurez-vous que "Django.contrib.staticfiles" est inclus dans vos INSTALLED_APPS.
c'est le numéro un dans cette liste de contrôle
Cela a fonctionné pour moi
{% load staticfiles %}
inclure {% load static%} juste au-dessus de la section dans le fichier html, qui aidera votre fichier HTML à charger vos fichiers css ou js
ajouter {% load static %}
en haut du fichier html, sous la ligne html DOCTYPE
{% load static%} ou {% load staticfiles%}
les deux fonctionneront. Assurez-vous simplement d'utiliser une quantité égale d'espaces entre l'ouverture et la fermeture de '{' et '%'.
C'est bon maintenant. Je l'ai résolu moi-même. Je suis désolé. J'ai confondu deux fichiers html similaires. Celui que j'ai mis ici (header.html) avait raison mais header_authenticated.html était faux.