Подключение файла javascript к django в статическом файле
Я прикрепляю js файл к моему Django, но у меня проблема, потому что JS не работает при просмотре сайта, когда Django видит стиль CSS файла. Я пробовал смотреть некоторые тотуриалы, но все та же проблема. Стрелки и т.д. не реагируют на нажатие.
Терминал:
[06/Oct/2022 11:11:50] "GET /home/ HTTP/1.1" 200 3381
[06/Oct/2022 11:11:50] "GET /static/css/style.css HTTP/1.1" 200 773
[06/Oct/2022 11:11:50] "GET /static/image/arrow-left.png HTTP/1.1" 200 375
[06/Oct/2022 11:11:50] "GET /static/image/arrow-right.png HTTP/1.1" 200 306
[06/Oct/2022 11:11:50] "GET /static/image/about-us.png HTTP/1.1" 200 276423
[06/Oct/2022 11:11:50] "GET /static/image/calculate-power.png HTTP/1.1" 200 359596
[06/Oct/2022 11:11:50] "GET /static/image/turbine-models.png HTTP/1.1" 200 730280
[06/Oct/2022 11:11:50] "GET /static/js/home_page.js HTTP/1.1" 200 1167
Шаблон домашней страницы:
{% extends 'turbineweb/turbineweb_extends.html' %}
{% load static %}
{% block section_one %}
<main>
<div id="slider">
<div id="top-row">
<img class="arrow left-class" id="arrow-left" src="{% static 'image/arrow-left.png' %}" />
<div id="slides-container">
<img class="slide active" src="{% static 'image/about-us.png' %}">
<img class="slide" src="{% static 'image/turbine-models.png' %}">
<img class="slide" src="{% static 'image/calculate-power.png' %}">
</div>
<img class="arrow right-class" id="arrow-right" src="{% static 'image/arrow-right.png' %}" />
</div>
<div id="bottom-row">
<div id="dots">
<div class="dot"></div>
<div class="dot"></div>
<div class="dot"></div>
</div>
</div>
</div>
<script src="{% static 'js/home_page.js' %}"></script>
</main>
{% endblock %}
JS:
let activeSlideNumber = 1;
let arrowLeft = document.querySelector('.arrow-left')
let arrowRight = document.querySelector('.arrow-right')
let hideActiveSlide = () => {
let activeElement = document.querySelector('.active');
activeElement.classList.remove('active')
}
let showSlide = (slideNumber) => {
hideActiveSlide();
document.querySelector('#slide'+slideNumber).classList.add('active')
}
let showNextSlide = () => {
if(activeSlideNumber === 3) {
activeSlideNumber = 1;
} else {
activeSlideNumber = activeSlideNumber + 1;
}
showSlide(activeSlideNumber);
};
let showPreviousSlide = () => {
if(activeSlideNumber === 1) {
activeSlideNumber = 3;
} else {
activeSlideNumber = activeSlideNumber - 1;
}
showSlide(activeSlideNumber);
};
for(let i = 1; i <= 3; i++) {
let showSlideI = () => {
activeSlideNumber = 1;
showSlide(i)
};
document.querySelector('#dol'+i).addEventListener('click', showSlideI);
}
arrowLeft.addEventListener('click', showNextSlide);
arrowRight.addEventListener('click', showPreviousSlide);
Проект:
- turbineweb(app)
- статический
- css
- style.css
- изображение
- image.png
- js
- home_page.js
- css
- templates
- init.py
- admin.py
- models.py
- статический
настройки:
# Static files (CSS, JavaScript, Images)
STATIC_URL = '/static/'
вместо этого:
<script src="{% static 'js/home_page.js' %}"></script>
попробуйте это:
<script src="{% static '/js/home_page.js' %}"></script>
И исправьте свою опечатку sttatic на static
В файле настроек:
STATIC_URL = '/static/'
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'static')]
Также в TEMPLATES в файле настроек, добавьте его:
'libraries' : {
'staticfiles': 'django.templatetags.static',
}
EX:
TEMPLATES = [
{
'BACKEND': 'django.template.backends.django.DjangoTemplates',
'DIRS': [os.path.join(BASE_DIR, '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',
],
'libraries' : {
'staticfiles': 'django.templatetags.static', #Added here
}
},
},
]
в моем urls.py я настроил static, но это не помогло - ответ на комментарий Sunderam Dubey
from django.urls import path, include
from django.conf.urls.static import static
from django.conf import settings
from . import views
urlpatterns = [
path('home/', views.home_page, name='home_page'),
] + static(settings.STATIC_URL, document_root=settings.STATIC_ROOT)
после добавления настроек:
STATIC_URL = '/static/'
STATICFILES_DIRS = [BASE_DIR / "static"]
необходимо удалить STATIC_ROOT
Ctrl + U дай мне это:
Кажется, я нашел решение. Мы смотрели не туда. Ваши настройки Django верны. Это ваш js файл, который выбирает неправильную кнопку:
Изменение:
let arrowLeft = document.querySelector('.arrow-left')
let arrowRight = document.querySelector('.arrow-right')
To:
let arrowLeft = document.getElementById('arrow-left')
let arrowRight = document.getElementById('arrow-right')
Редактировать
Я внимательно изучил ваш js-файл и обнаружил некоторые отсутствующие селекторы.
Я добавил id="sliderX" и id="dotX". Без них ваш js выбросил ошибку и не был выполнен.
<main>
<div id="slider">
<div id="top-row">
<img class="arrow left-class" id="arrow-left" src="/static/image/arrow-left.png" />
<div id="slides-container">
<img class="slide active" id="slide1" src="/static/image/about-us.png">
<img class="slide" id="slide2" src="/static/image/turbine-models.png">
<img class="slide" id="slide3" src="/static/image/calculate-power.png">
</div>
<img class="arrow right-class" id="arrow-right" src="/static/image/arrow-right.png" />
</div>
<div id="bottom-row">
<div id="dots">
<div class="dot" id="dot1"></div>
<div class="dot" id="dot2"></div>
<div class="dot" id="dot3"></div>
</div>
</div>
</div>
<script src="/static/js/home_page.js"></script>
</main>
Я не изменял ваш js, кроме изменения, которое я упомянул в верхней части этого сообщения.
Примечание: Щелкните правой кнопкой мыши в браузере Chrome > Inspect, а затем в верхней части боковой панели нажмите "Console". Здесь вы увидите все ошибки js, включая ссылки для отладки.