Общая папка express.js не распознается

Я разработал простой сервер в Node.js, используя Express, и установил папку public для обслуживания статических файлов.

В моем корневом index.js у меня есть следующий код:

const express = require('express');
const app = express();
const http = require('http').Server(app);
const fs = require('fs');

app.use(express.static(__dirname + '/public'));

app.get('/', (req, res) =>  {
    res.sendFile(__dirname + '/public/index.html'); 
});

http.listen(3000, () => console.info('started server on *:3000'));

И структура каталогов такова:

root 
|---index.js
|---package.json
|---public
|   |---index.html
|   |---cs
|   |   |---index.css
|   |---js
|   |   |---index.js

В index.html в папке public у меня есть следующий код:

<head>
    <script src = "js/index.js"></script>
    <link rel = "stylesheet" src = "css/index.css" type = "text/css" >
</head>

Но CSS не отображается. Как я могу это решить?

я думаю, что теги link имеют атрибуты href вместо src

Sudhir Bastakoti 04.04.2021 09:50

есть отвечать, я думаю, это может вам помочь

alireza javanmardi 04.04.2021 10:05

@SudhirBastakoti, переход на href, работал, но в некоторых ответах предлагается перейти на src ... но большое спасибо ..

Maifee Ul Asad 04.04.2021 10:55

Возможно, это опечатка, но при редактировании вашего вопроса я заметил, что у вас в структуре каталогов есть папка cs вместо папки css.

Bart Hofland 04.04.2021 15:58
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
Поведение ключевого слова "this" в стрелочной функции в сравнении с нормальной функцией
В JavaScript одним из самых запутанных понятий является поведение ключевого слова "this" в стрелочной и обычной функциях.
Концепция локализации и ее применение в приложениях React ⚡️
Концепция локализации и ее применение в приложениях React ⚡️
Локализация - это процесс адаптации приложения к различным языкам и культурным требованиям. Это позволяет пользователям получить опыт, соответствующий...
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
Улучшение производительности загрузки с помощью Google Tag Manager и атрибута Defer
В настоящее время производительность загрузки веб-сайта имеет решающее значение не только для удобства пользователей, но и для ранжирования в...
Безумие обратных вызовов в javascript [JS]
Безумие обратных вызовов в javascript [JS]
Здравствуйте! Юный падаван 🚀. Присоединяйся ко мне, чтобы разобраться в одной из самых запутанных концепций, когда вы начинаете изучать мир...
Система управления парковками с использованием HTML, CSS и JavaScript
Система управления парковками с использованием HTML, CSS и JavaScript
Веб-сайт по управлению парковками был создан с использованием HTML, CSS и JavaScript. Это простой сайт, ничего вычурного. Основная цель -...
JavaScript Вопросы с множественным выбором и ответы
JavaScript Вопросы с множественным выбором и ответы
Если вы ищете платформу, которая предоставляет вам бесплатный тест JavaScript MCQ (Multiple Choice Questions With Answers) для оценки ваших знаний,...
0
4
40
2

Ответы 2

Попробуйте изменить это:

app.use(express.static(__dirname + '/public'));

К этому:

app.use(express.static('public'));

Замените атрибут src в теге link на href. Если это не сработает, попробуйте следующее решение.

Я считаю, что ваш сервер работает на http://localhost:3000/

Поэтому обновите URL-адрес в src вашего index.html в общей папке, добавив базовый URL-адрес, как я сделал ниже.

<head>
    <script src = "http://localhost:3000/js/index.js"></script>
    <link rel = "stylesheet" href = "http://localhost:3000/css/index.css" type = "text/css" >
</head>

Другие вопросы по теме