Есть компонент Header
import React from "react";
import './Header.css';
export default class Header extends React.Component{
render() {
return (
<header className="header" id="header">
<div className="container">
<div className="row align-items-center">
<div className="col-2 offset-1 col-sm-2 offset-sm-1 col-md-4 offset-md-0 ">
<div className="header-logo"></div>
</div>
<div className="col-9 col-sm-9 col-md-8">
<div className="header-contacts">
<div className="header-contacts__phones">
<a href="tel:+380981234567" className="header-contacts__phone">38 (098)123-45-67</a>
<a href="tel:+380971234567" className="header-contacts__phone">38 (097)123-45-67</a>
</div>
<a className="button header-contacts__button button__cta" href="#popup">
<img src="/img/header/header-btn-icon.png" alt="phone-icon-btn"/>
<span className="hidden-mobile hidden-sm">Заказать звонок</span>
</a>
</div>
</div>
</div>
</div>
</header>
);
}
}
В JSX в теге img обращаемся к изображению, которое храниться в папке public - все отлично изображение видно.
Если обращаемся к изображению из css файла, который подключен к компоненту Header
.header-logo{
width: 191px;
height: 61px;
background: url('/img/header/header-logo.png') 0 center; // ошибка !!!
background-size: cover;
}
Получаю ошибку
./src/components/Header/Header.css (./node_modules/css-loader/dist/cjs.js??ref--5-oneOf-4-1!./node_modules/postcss-loader/src??postcss!./src/components/Header/Header.css)
Error: Can't resolve '/img/header/header-logo.png' in
1) Вопрос почему я не могу достучаться к изображению которое лежит в папке public из css?
Изображение необходимо подключить именно через css - использую для фона секции и не только
2) Если изображение лежит в папке компонента Header - все отлично - логотип отображается
3) Как лучше хранить картинки в общем?
- все изображения в папке (public/img/header)
- в конкретном компоненте, к которому относятся изображения? (Header/img)
Вариант в котором отдельно импортируем картинку в Header.js и подключаем в нем же через инлайн-стили не подходит, хочется именно чтобы было прописано в отдельном файле стилей.
Буду благодарен за ответы!
Логотип задан в css