Issue
I am developing a webpage that has two layouts (Mobile & Desktop). In the Desktop layout, I want to have a vertically split page where the main content will be on the right side, and the header, footer, and content image is on the left side (Check the image below).
On mobile, I want the layout to look different where the page is no longer split, and the components flow starts with the header, followed by the main content, and ends with the footer. The content image is no longer displayed (Check the image below).
The problem I am having is in the mobile layout. I want to rearrange the displayed components without having to re-render them using react hooks, as the structure of components created are something like this:
Page
├─ Left Pane
│ ├─ Header
│ ├─ Image
│ ├─ Footer
│
│
├─ Right Pane
├─ Main content
And the desired mobile structure would look like this:
Page
├─ Header
├─ Main Content
├─ Footer
I tried to have different CSS styles depending on the media query using display/padding/margin properties and got it somewhat working, but that was a hacky solution when the content of the footer is too long, it will overlap with the main content and the page fails to display components properly.
Is there any way to do this without having to trigger a React re-render? Or is there a better structure suggestion for my page that ensures left and right panes in the desktop version are completely isolated from each other and display the mobile site properly?
Solution
It's hard to tell without some code, but if you are using flexbox you can use order
in your media queries if you want a pure css solution. Some info here: https://developer.mozilla.org/en-US/docs/Web/CSS/CSS_Flexible_Box_Layout/Ordering_Flex_Items#the_order_property
Answered By - Authentic Science
0 comments:
Post a Comment
Note: Only a member of this blog may post a comment.