Для установки нескольких фоновых изображений на div
вы можете использовать свойство css background-image
. Это выглядит так:
background-image: url('/first/image.jpg'), url('second/image.jpg') ...;
Ваше приложение может хранить URL-адреса изображений и состояние отображения в массиве, который вы можете обновлять посредством взаимодействия с пользователем или в зависимости от времени. Затем вы можете динамически построить значение свойства css из URL-адресов изображений для отображения. Пример приложения:
const IMAGES = [
// this could be real paths instead
/* red */ "",
/* green */ "",
/* blue */ ""
];
const Toggle = ({ layers, onToggle }) => {
// this component is just for demonstration of dynamically toggling images
return layers.map((layer, idx) => (
<button
key={layer.url}
onClick={() => onToggle(idx)}
style={{ background: layer.display ? `url(${layer.url})` : "none" }}
>{`Toggle Layer ${idx}`}</button>
));
};
const Layers = () => {
// we initialize the array from the image urls and set every layer to display: false
const [layers, setLayers] = useState(() =>
IMAGES.map(url => ({ url, display: false }))
);
// this method toggles the display state of the layer at idx
const handleToggleLayer = idx =>
setLayers(current =>
current.map((layer, i) =>
i === idx ? { ...layer, display: !layer.display } : layer
)
);
return (
<div>
<Toggle layers={layers} onToggle={handleToggleLayer} />
<div
className="layers"
style={{
backgroundImage: layers
.filter(layer => layer.display)
.map(layer => `url(${layer.url})`)
.join(", ")
}}
/>
</div>
);
};
Live Demo:
Note that the first image listed will be on top (the front-most).
The example uses строки шаблона , чтобы обернуть пути к изображениям в url( ... )
и .join()
чтобы присоединиться к ним.