静态文件被接收,但在 Django 中不起作用

static files are recieved but not working in django

本文关键字:但在 Django 不起作用 文件 静态      更新时间:2023-09-26

>我正在使用 django 1.7,

这是我 settings.py 文件

STATIC_URL = '/static/'
STATICFILES_DIRS = (
os.path.join(BASE_DIR, "assets"),
)
STATIC_ROOT = "absolute/path/to/static"

这里的资产是我创建的文件夹,包含所有CSS和JS文件。之后,我运行命令 collectstatic 并创建了一个静态文件夹。

这就是我在 HTML 中调用 CSS 和 JS 文件的方式

{% load staticfiles %}

<meta charset="utf-8">
<meta http-equiv="X-UA-Compatible" content="IE=edge">
<meta name="viewport" content="width=device-width, initial-scale=1">
<meta name="description" content="">
<meta name="author" content="">
<title>Login</title>
<link href="{% static '/static/css/bootstrap.min.css' %}" rel="stylesheet">

问题是当我运行服务器时,所有 CSS 和 JS 文件都被接收到(在开发人员部分显示 200 OK),但没有应用 CSS,我的意思是 HTML 页面看起来很原始,好像没有应用 CSS。

我做错了什么,我是 django 的新手,任何人都可以指出我正确的方向

提前谢谢。

编辑:

我在浏览器开发人员控制台中得到这个

资源解释为样式表,但使用 MIME 类型的文本/纯文本传输:".../static/css/bootstrap.min.css"。

您应该从 css 文件的路径中删除/static/前缀:

<link href="{% static 'css/bootstrap.min.css' %}" rel="stylesheet">