[英]Css file not loading in ejs
问题 - 我无法弄清楚为什么 CSS 文件没有在 ejs 中加载。终端没有给出错误消息。 它的显示消息 -GET /assets/css/style.css 404 159 - 0.674 毫秒。服务器(本地主机运行良好)。
我尝试了什么:app.use(express.static(__dirname + '/assets/css')); 这也给出了相同的消息。我什至尝试更改文件路径并尝试了其他方法,但没有任何效果。
我的 ejs 代码 -
const express = require('express');
const dotenv = require('dotenv');
const app = express();
const morgan =require('morgan');
const path = require('path');
dotenv.config({path:'./config.env'});
const PORT = process.env.PORT ||8080
// parse request to body-parser
app.use(express.urlencoded({ extended: true }));
app.use(express.json());
// log request
app.use(morgan('tiny'));
// set view engine
app.set("view engine","ejs");
app.set("views",path.join(__dirname,"views"))
//load assets
app.use('./css',express.static(path.resolve(__dirname,"assets/css")));
//css/style.css
app.use('/img',express.static(path.resolve(__dirname,"assets/img")));
app.use('/js',express.static(path.resolve(__dirname,"assets/js")));
app.use(express.static("assets"));
app.get('/', (req,res)=>{
res.render('index');
});
app.listen(PORT,()=>{console.log('Server is running Sucessfully ');});
_header.ejs 文件
<html>
<head>
<link rel="stylesheet" href="https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.3/css/all.min.css" integrity="sha512-iBBXm8fW90+nuLcSKlbmrPcLa0OT92xO1BIsZ+ywDWZCvqsWgccV3gFoRBv0z+8dLJgyAHIhR35VZc2oM/gI1w==" crossorigin="anonymous"/>
<link rel="stylesheet" type="text/css" href ="/assets/css/style.css">
</head>
<body>
<!----HEader-->
<header id="header">
<nav>
<div class ="text-center">
<a href ="/" class ="nav-brand text-dark">User Management System</a>
</div>
</nav>
</header>
File structure
-assets
--css
---style.css
app.use
用于将 gobal 中间件添加到您的路由中。
基本语法如下:-
app.use('/someRoute', middleware);
代替...
app.use('./css',express.static(path.resolve(__dirname,"assets/css")));
//css/style.css
app.use('/img',express.static(path.resolve(__dirname,"assets/img")));
app.use('/js',express.static(path.resolve(__dirname,"assets/js")));
app.use(express.static("assets"));
尝试...
app.use(express.static(path.join(__dirname, "assets")));
这将为 web 上的整个assets
文件夹提供服务。
上面的代码行将为您的服务器拥有和将来拥有的每条路由提供您的assets
文件夹及其所有内容到 web。
由于现在assets
文件夹已经提供,您实际上不需要将assets
添加到<link>
标记内的href
中。
css 文件的路径是assets/css/styles.css
。
早些时候,您的服务器正在寻找assets/assets/css/styles.css
,因为assets
已经提供。
在您的_header.ejs
文件中,将链接的href
更改为:-
<link rel="stylesheet" type="text/css" href ="/css/style.css">
现在服务器会寻找assets/css/styles.css
存在所以现在没有错误。
我希望这有帮助。
我不明白你想用这个做什么......
app.use('./css',express.static(path.resolve(__dirname,"assets/css")));
app.use('/img',express.static(path.resolve(__dirname,"assets/img")));
app.use('/js',express.static(path.resolve(__dirname,"assets/js")));
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.