情况
文件夹结构
settings.py
#actual folder name where we save our images
STATICFILES_DIRS = [os.path.join(BASE_DIR, 'mainprojectfolder/static/')]
# Removed based on: https://stackoverflow.com/questions/60354519/django-base-html-extended-to-homepage-html-static-images-appear-but-home-css-d
STATIC_ROOT = os.path.join(BASE_DIR, 'static')
#this_is_what_U_see_in_URL_bar_for_static_files
STATIC_URL = '/static/'
base.html
<!doctype html>
<html lang="en">
{% load static %}
<!-- SYLES & BASICS-->
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width, initial-scale=1, shrink-to-fit=no">
<link rel="shortcut icon" type="image/png" href="{% static 'favicon.ico' %}"/>
<title> </title>
<link rel="canonical" href="https://getbootstrap.com/docs/4.3/examples/carousel/">
<link rel="stylesheet" href="static/css/bootstrap/bootstrap.min.css"> <!-- -->
<link href="static/css/style.min.css" rel="stylesheet">
</head>
<body>
<header>
...
</header>
{% block content %}
{% endblock %}
<script src="static/public/js/jquery/jquery.min.js"></script>
<script src="static/public/js/popper/popper.min.js"></script>
<script src="static/public/js/bootstrap/bootstrap.min.js"></script>
</body>
</html>
signin.html
{% extends 'ch/templates/base_emp.html' %}
{% load static %}
{% block content %}
<!-- MY COTENT, no imports only file requests-->
{% endblock %}
错误消息
[31/Mar/2020 12:31:22] "GET /accounts/signup HTTP/1.1" 200 19987
Not Found: /accounts/static/public/js/jquery/jquery.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/jquery/jquery.min.js HTTP/1.1" 404 3285
Not Found: /accounts/static/css/style.min.css
[31/Mar/2020 12:31:22] "GET /accounts/static/css/style.min.css HTTP/1.1" 404 3246
Not Found: /accounts/static/public/js/popper/popper.min.js
[31/Mar/2020 12:31:22] "GET /assets/images/logo-icon.png HTTP/1.1" 404 2808
Not Found: /accounts/static/css/bootstrap/bootstrap.min.css
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/popper/popper.min.js HTTP/1.1" 404 3285
Not Found: /accounts/static/public/js/bootstrap/bootstrap.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/css/bootstrap/bootstrap.min.css HTTP/1.1" 404 3288
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/bootstrap/bootstrap.min.js HTTP/1.1" 404 3303
Not Found: /accounts/static/public/js/popper/popper.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/popper/popper.min.js HTTP/1.1" 404 3285
Not Found: /accounts/static/public/js/bootstrap/bootstrap.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/bootstrap/bootstrap.min.js HTTP/1.1" 404 3303
Not Found: /accounts/static/public/js/jquery/jquery.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/jquery/jquery.min.js HTTP/1.1" 404 3285
Not Found: /accounts/static/public/js/popper/popper.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/popper/popper.min.js HTTP/1.1" 404 3285
Not Found: /accounts/static/public/js/bootstrap/bootstrap.min.js
[31/Mar/2020 12:31:22] "GET /accounts/static/public/js/bootstrap/bootstrap.min.js HTTP/1.1" 404 3303
[31/Mar/2020 12:31:22] "GET /static/favicon.ico HTTP/1.1" 200 15406
更正方法
STATICFILES_DIRS = (os.path.join(BASE_DIR, 'static'),)
STATIC_ROOT = os.path.join(os.path.dirname(BASE_DIR), 'static') #if i turn on this I get another python related error
STATIC_URL = '/static/'
TEMPLATE_DIRS = (os.path.join(BASE_DIR, 'templates'),)
STATIC_ROOT = os.path.join(os.path.dirname(BASE_DIR), 'static')
/accounts/static/css/style.min.css
,但我仍然遇到该错误。 Not Found: /accounts/static/css/style.min.css
[31/Mar/2020 12:31:22] "GET /accounts/static/css/style.min.css HTTP/1.1" 404 3246
<script src="static/public/js/jquery/jquery.min.js"></script>
<script src="static/public/js/popper/popper.min.js"></script>
<script src="static/public/js/bootstrap/bootstrap.min.js"></script>
<script src="{% static 'public/js/jquery/jquery.min.js' %}"></script>
<script src="{% static 'public/js/popper/popper.min.js' %}"></script>
<script src="{% static 'public/js/bootstrap/bootstrap.min.js' %}"></script>
Not Found: /accounts/static/css/style.min.css
Not Found: /accounts/static/images/small.png
Not Found: /accounts/static/css/bootstrap/bootstrap.min.css
[31/Mar/2020 13:51:06] "GET /accounts/static/css/style.min.css HTTP/1.1" 404 3246
[31/Mar/2020 13:51:06] "GET /accounts/static/images/small.png HTTP/1.1" 404 3270
[31/Mar/2020 13:51:06] "GET /accounts/static/css/bootstrap/bootstrap.min.css HTTP/1.1" 404 3288
<link rel="stylesheet" href="static/css/bootstrap/bootstrap.min.css">
更改为此<link rel="stylesheet" href="{% static 'css/bootstrap/bootstrap.min.css %}">
会产生以下错误:TemplateSyntaxError at /accounts/signup
Could not parse the remainder: ''css/bootstrap/bootstrap.min.css' from ''css/bootstrap/bootstrap.min.css'
Request Method: GET
Request URL: http://127.0.0.1:8000/accounts/signup
Django Version: 3.0
Exception Type: TemplateSyntaxError
Exception Value:
Could not parse the remainder: ''css/bootstrap/bootstrap.min.css' from ''css/bootstrap/bootstrap.min.css'
Exception Location: /Users/..../site-packages/django/template/base.py in __init__, line 662
Python Executable: /Users/..../bin/python3
Python Version: 3.7.3
Python Path:
['/Users/..../project',
'/Users/..../project/ven/lib/python37.zip',
'/Users/..../project/ven/lib/python3.7',
'/Users/..../project/ven/lib/python3.7/lib-dynload',
'/usr/local/Cellar/python/3.7.3/Frameworks/Python.framework/Versions/3.7/lib/python3.7',
'/Users/..../lib/python3.7/site-packages']
Server time: Tue, 31 Mar 2020 14:00:00 +0000
答案 0 :(得分:2)
您应该更改:
<script src="static/public/js/jquery/jquery.min.js"></script>
...
进入
<script src="{% static 'public/js/jquery/jquery.min.js' %}"></script>
...
答案 1 :(得分:1)
看看它试图获取的路径:
/accounts/static/public/js/jquery/jquery.min.js
这不是您想要的,因为在urls.py中,任何以/accounts
开头的内容都指向您的身份验证视图。
问题是您为静态文件使用了相对路径:static/public/js
并非以/
开头,因此它是相对于当前页面的。如果页面是/account/login
,则路径是相对于/account/
的。
因此,基本上,您需要拥有/static/public/js/...
。它以/
开头,因此是绝对路径。
但是定义STATIC_URL
的全部原因是,您不必在模板中记住它。为此,有一个static
模板标签:
{% load static %}
<!-- scripts -->
<script src="{% static 'public/js/...' %}"></script>
<!-- css files -->
<link rel="stylesheet" href="{% static 'css/bootstrap/bootstrap.min.css' %}">
<!-- images -->
<img src="{% static 'images/small.png' %}">
在引用静态文件时,始终在模板的各处使用{% static %}
,这是最重要的。