Quantcast
Viewing all articles
Browse latest Browse all 1318

Flex direction column and fill screen width [duplicate]

I have a list of elements of varying height and want to lay them out such that the full screen width gets filled (but not overflown with a horizontal scrollbar):

Image may be NSFW.
Clik here to view.
enter image description here

How can I accomplish this via CSS? I cannot simply switch to flex-direction: row as there would be large gaps between rows due to the varying heights of the elements.

Here is my hacky attempt via JS:https://codesandbox.io/s/dreamy-joliot-9n3woy?file=/src/App.js

import React, { useState, useEffect } from "react";const BOX_WIDTH = 200;const boxHeights = [...Array(500)].map(() => Math.random() * 100);export default function App() {  const ref = React.useRef();  const [originalHeight, setOriginalHeight] = useState();  useEffect(() => {    if (!originalHeight && ref.current?.clientHeight) {      setOriginalHeight(ref.current?.clientHeight);    }  }, [originalHeight, ref.current?.clientHeight]);  const [height, setHeight] = useState();  useEffect(() => {    if (originalHeight && ref.current?.clientWidth) {      setHeight(        originalHeight / Math.floor(ref.current?.clientWidth / BOX_WIDTH) / 0.9      );    }  }, [ref.current?.clientWidth, originalHeight]);  return (<><div        ref={ref}        style={{          display: "flex",          flexDirection: "column",          flexWrap: "wrap",          ...(height && { height })        }}>        {[...Array(500)].map((_, i) => (<div            style={{              border: "solid",              width: BOX_WIDTH,              height: boxHeights[i],              margin: "10px"            }}          />        ))}</div></>  );}

Viewing all articles
Browse latest Browse all 1318

Trending Articles



<script src="https://jsc.adskeeper.com/r/s/rssing.com.1596347.js" async> </script>