2015-11-19 12 views
1

ребята IAM в Newbee Джанго .. я пытался загрузить статические файлы, такие как изображения и CSS в шаблоне .. но он не работает .. вот кодdjango включают статические файлы в шаблонах?

---------- -settings.py ----------

""" 

Generated by 'django-admin startproject' using Django 1.8.2. 

For more information on this file, see 
https://docs.djangoproject.com/en/1.8/topics/settings/ 

For the full list of settings and their values, see 
https://docs.djangoproject.com/en/1.8/ref/settings/ 
""" 

# Build paths inside the project like this: os.path.join(BASE_DIR, ...) 
import os 

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


# Quick-start development settings - unsuitable for production 
# See https://docs.djangoproject.com/en/1.8/howto/deployment/checklist/ 

# SECURITY WARNING: keep the secret key used in production secret! 
SECRET_KEY = '#####################################' 

# SECURITY WARNING: don't run with debug turned on in production! 
DEBUG = True 

ALLOWED_HOSTS = [] 


# Application definition 

INSTALLED_APPS = (
    'django.contrib.admin', 
    'django.contrib.auth', 
    'django.contrib.contenttypes', 
    'django.contrib.sessions', 
    'django.contrib.messages', 
    'django.contrib.staticfiles', 
) 

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', 
    'django.middleware.clickjacking.XFrameOptionsMiddleware', 
    'django.middleware.security.SecurityMiddleware', 
) 

ROOT_URLCONF = 'hostel_management.urls' 

TEMPLATES = [ 
    { 
     'BACKEND': 'django.template.backends.django.DjangoTemplates', 
     'DIRS': ['hostel_management/templates/'], 
     'APP_DIRS': True, 
     'OPTIONS': { 
      'context_processors': [ 
       'django.template.context_processors.debug', 
       'django.template.context_processors.request', 
       'django.contrib.auth.context_processors.auth', 
       'django.contrib.messages.context_processors.messages', 
      ], 
     }, 
    }, 
] 

WSGI_APPLICATION = 'hostel_management.wsgi.application' 


# Database 
# https://docs.djangoproject.com/en/1.8/ref/settings/#databases 

DATABASES = { 
    'default': { 
     'ENGINE': 'django.db.backends.sqlite3', 
     'NAME': os.path.join(BASE_DIR, 'db.sqlite3'), 
    } 
} 


# Internationalization 
# https://docs.djangoproject.com/en/1.8/topics/i18n/ 

LANGUAGE_CODE = 'en-us' 

TIME_ZONE = 'UTC' 

USE_I18N = True 

USE_L10N = True 

USE_TZ = True 


# Static files (CSS, JavaScript, Images) 
# https://docs.djangoproject.com/en/1.8/howto/static-files/ 

STATIC_URL = 'hostel_management/static/' 


STATICFILES_DIRS = (
    os.path.join(BASE_DIR, "static"), 
    '/var/www/static/', 
) 

--------- --------- urls.py

from django.conf.urls import include, url 
from django.contrib import admin 
from views import index 

urlpatterns = [ 
    url(r'^admin/', include(admin.site.urls)), 
    url(r'^index/$', index) 

] 

- ----- index.html ------

{% load static from staticfiles %} 
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script> 
    <script src="{% static "scripts.js" %></script> 
    <img src="{% static "large-image.jpg" %}" alt="img" /> 

ни изображения, ни файл JS загружается ..

файловая система выглядит следующим образом

hostel_management 
├── manage.py 
├──hostel_management 
| ├──templates 
├──static 
| ├──large_image.jpg 
| ├──script.js 

ответ

1

Вы говорите, что у вас есть script.js но вы пытаетесь получить scripts.js.

{% load static %} 
    <script src="http://ajax.googleapis.com/ajax/libs/jquery/1.11.0/jquery.min.js"></script> 
    <script src="{% static 'script.js' %></script> 
    <img src="{% static "large-image.jpg" %}" alt="img" /> 

Также вы должны переместить static папку на место, где ваш manage.py помещается и установить STATIC_URL = '/static/'

+0

удален. склеивание .. в любом случае это сработало теперь, поставив статическую папку, где manage.py был .. спасибо – Sidharth

+0

@ Сидхарт, о, хорошо, это здорово! – pythad

+0

, но проблема была прежде.у меня был «/ hostel_management/static /» в статическом url .. и статической папке внутри папки hostel_management .. почему он тогда не работал? @pythad – Sidharth

1

Существует ошибка в том, как вы загрузите статические файлы. Загрузите это так:

<link rel="stylesheet" href="{% static "script.js" %}"> 

Я думаю, что есть ошибка на вас settings.py

где ваш путь загрузки статического файла является:

STATICFILES_DIRS = (os.path.join(BASE_DIR, "static"),"/var/www/static/', 

это путь в соответствии с django docs,

STATIC_URL = '/static/' 
STATIC_ROOT = os.path.join(BASE_DIR, 'static') 

, если вы можете создать полную структуру папок в своем проекте, а затем сообщить об этом exac t изменения будут возможны.

0

Изменение статического URL в

STATIC_URL = '/static/' 

В шаблоне, поместите следующую строку в начале

{% load staticfiles %} 

Для статических файлов, которые требуются весь ваш проект, вы можете поместить их в том же каталоге в котором вы управляете .py. Для статических файлов, привязанных к определенному приложению, вы можете использовать следующие настройки в ваших settings.py. Как и в вашем случае

STATICFILES_DIRS = (
os.path.join(BASE_DIR, "static"), 
'hostel_management/static/', 

)

Там нет необходимости включать URL в urls.py, как вы сделали. Это не подходит для использования в производстве. Вы также можете попробовать, перемещая каталог шаблонов на том же уровне, что и ваш статический каталог файлов.

Смежные вопросы