How to flex wrap 4 elements 2 by 2 - html

I'm trying to keep my logo "Reservia" and my LI "S'inscrire" on the same line and wrap my 2 other LI "Hebergement" and "Activités" on a line under this first one but it doesn't work.
Here is my Header
<header>
<div id="containerHeader">
<img src="images/logo/Reservia.svg" class="test" alt="Logo reservia">
<nav class="Navmenu">
<ul class="liMenu">
<li class="liMenu--list liMenu--list_nocolor">
Hebergement
</li>
<li class="liMenu--list liMenu--list_nocolor">
Activités
</li>
<li class="liMenu--list liMenu--list_blue">
S'inscrire
</li>
</ul>
</nav>
</div>
</header>
And here is my CSS
#containerHeader{
flex-wrap: wrap;
}
.navMenu,
.liMenu {
justify-content: center;
padding-right: 80px;
}
.liMenu--list {
list-style: none;
}
.test{
order: -1;
}
.link--navbar {
border-bottom: 4px solid lightgrey;
border-top: none;
padding-bottom: 15px;
}
.link--navbar:hover {
border-top: none;
}
And I put my 2 screenshots ( what it looks like and what I want ) :)
Thanks a lot

img, li {
width: 50%
}
Try adding 50% width to the img and li elements. This will ensure that a single element takes up half the width, which will result in two elements per row.
You may need to use media queries if you want a different look for different devices.

Related

CSS filter property disabling fixed position on navigation bar [duplicate]

This question already has an answer here:
Why does clip-path (and other properties) affect the stacking order (z-index) of elements later in DOM?
(1 answer)
Closed 2 years ago.
I made my navigation bar and positioned it (fixed), and it works fine. I was able to scroll down and all. As soon has I added filter (brightness) to it the image on my page, the navigation bar disappeared. I have tried using pseudo-elements and setting the position (absolute/relative), I set the filter property to the container of the child element of the image, it still didn't work. Can someone help me on how to have my navigation bar display on fixed position and still have the image filtered. Thanks in Advance.
nav {
position: fixed;
background-color: #fff;
}
nav ul {
margin: 0;
padding: 0;
}
.navbar-brand {
padding-right: 20px;
}
nav li {
display: inline-block;
padding: 10px;
}
nav a {
color: #000;
text-decoration: none;
}
nav a:hover {
color: #ff6600;
text-decoration: none;
}
.title-image img {
width: 100%;
height: 300px;
filter: brightness(60%);
}
<nav>
<ul>
<li>
<a class="navbar-brand" href="#">Navbar Brand</a>
</li>
<li>
Home
</li>
<li>
About
</li>
<li>
services
</li>
</ul>
</nav>
<div class="title-image">
<img src="https://images.unsplash.com/photo-1599546824091-f49550ce8cbc?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=crop&w=500&q=60">
</div>
JSfiddle Demo
Just add z-index to your nav element as follow
nav{
position: fixed;
background-color: #fff;
z-index:999;
}
nav ul{
margin: 0;
padding: 0;
}
.navbar-brand{
padding-right: 20px;
}
nav li{
display: inline-block;
padding: 10px;
}
nav a{
color: #000;
text-decoration: none;
}
nav a:hover{
color: #ff6600;
text-decoration: none;
}
.title-image img{
width: 100%;
height: 300px;
filter: brightness(60%);
}
<nav>
<ul>
<li>
<a class="navbar-brand" href="#">Navbar Brand</a>
</li>
<li>
Home
</li>
<li>
About
</li>
<li>
services
</li>
</ul>
</nav>
<div class="title-image">
<img src="https://images.unsplash.com/photo-1599546824091-f49550ce8cbc?ixlib=rb-1.2.1&ixid=eyJhcHBfaWQiOjEyMDd9&auto=format&fit=crop&w=500&q=60">
</div>
The navbar didn't disappear, it is just beneath the image. To have it in front, you should use z-index: 10; (or any value greater than 0).
See more at : https://developer.mozilla.org/en-US/docs/Web/CSS/z-index
In addition, keep in mind that your image - or any element after your navbar - will be positioned on top of your page. May be you'll want to let the equivalent of the navbar height as space before any content.

Best way to get li elements to scale down alongside an image

Hello once again Stackoverflow,
I have a flex-container with one large image (960x660) with 6 li elements similar to tabs on the side of it that line up with the images height(pic here- https://imgur.com/zSqFNmx). I would like the entire container to scale the same way that the image does. I have the image on the left set to a width of 100%. However I have the li elements width explicitly set by px(wrong of course). Which gives me this when I resize my window (pic- https://imgur.com/3RrVpZs).
My question is what is the best route to go so that I get all of the LI elements and text within to resize alongside the image to the left. Basically I want the entire container to be able to scale down completely. All while still lining up with the image at its full height.
Ive included a code pen example however the images do not work the same way im guessing due to the code pen frame around all of it?
HTML
<!-- HEADER START -->
<div id="flexContainer">
<div id="bigImage">
<img src="http://getdrawings.com/colorings/marvel-deadpool-coloring-pages-10.jpg">
</div>
<ul class="flexUL">
<li class="vm_clickable" id="organic" data-src="http://getdrawings.com/colorings/marvel-deadpool-coloring-pages-10.jpg" data-url="/organic"> Organic </li>
<li class="vm_clickable" id="glutenFree" data-src="https://www.bemea.com/wp-content/uploads/2018/11/Hero_SPE-V3_960x660.jpg" data-url="/gluten-free-shopping"> Gluten-Free </li>
<li class="vm_clickable" id="sugarFree" data-src="https://cdn.wallpapersafari.com/25/1/0yt8rf.jpg" data-url="/productsearch.aspx?rid=1041.05"> Sugar-Free</li>
<li class="vm_clickable" id="vegan" data-src="https://1iu5gpsjoqnqr.wpcdn.shift8cdn.com/wp-content/uploads/2019/09/960x660-SoWalWIne-1.jpg" data-url="/vegan"> Vegan </li>
<li class="vm_clickable" id="keto" data-src="https://cdn.wallpapersafari.com/66/32/4YHl2n.jpg" data-url="/keto-diet-essentials"> Keto </li>
<li class="vm_clickable" id="paleo" data-src="https://static.zerochan.net/Frozen.(Disney).full.1819021.jpg" data-url="/paleo"> Paleo </li>
</ul>
</div>
</div> <!-- deal wrapper end -->
CSS
#flexContainer {
display: flex;
width:100%;
height:auto;
flex-wrap:nowrap;
}
#bigImage > img{
width: 100%;
}
.flexUL{
display: flex;
flex-direction: column;
flex-wrap:nowrap;
}
.flexUL > li {
height: 100px;
width:320px;
}
.flexUL > li > a{
color: white;
font-size: xx-large;
margin-left: 20px;
}
.flexUL > li:hover > a:after{
content: '\203A';
font: 300 36px/18px "Roboto Slab";
margin-left: .2em;
height: 24px;
vertical-align: middle;
display: inline-block;
color: white;
}
#organic{
background-color: #ccb3d1;
}
#organic:hover{
background-color: #B7A1BC;
}
#glutenFree{
background-color: #e7b020;
}
#glutenFree:hover{
background-color: #CF9D1C;
}
#sugarFree{
background-color: #f07f53;
}
#sugarFree:hover{
background-color: #D8724A;
}
#vegan{
background-color: #889a2c;
}
#vegan:hover{
background-color: #7A8A27;
}
#keto{
background-color: #f49382;
}
#keto:hover{
background-color: #DB8475;
}
#paleo{
background-color: #9e5860;
}
#paleo:hover{
background-color: #8E4F56;
}
/* MEDIA QUERIES */
https://codepen.io/gchis66/pen/gOPqoeX
Any help is appreciated. Something tells me im missing very obvious solutions

Align div in li as center

Here is the fiddle:
https://jsfiddle.net/5jnnutg8/
My question is how can I align the "something #" list items as center and inline. One can see the "Hi" title is aligned in the center using text-align: center in css, but this doesn't seem to work for the list items.
Is there a pure css way of doing this without messing around with the <div>, <ul>, and <li> structure, as I am using a plugin for wordpress and it would be a pain to change this.
I want it to be that the "something #" list items are centered aligned, and if the browser is resized the "something 3" drops down but is still centered -- hope that makes sense.
Thanks!
Do not use float: left, simply use display: inline-block;
li {
display: inline-block;
}
Working demo
.list-holder {
background: black;
height: 100px;
color: white;
text-align:center;
}
.div-list-item {
background: red;
color: black;
margin-left: 10px;
}
.ul-class {
list-style: none;
padding: 0;
}
li {
display: inline-block;
}
a {
display: black;
}
<div class="list-holder">
Hi
<ul class="ul-class">
<li class="li-class">
<div class="div-list-item">
Something 1
</div>
</li>
<li class="li-class">
<div class="div-list-item">
Something 2
</div>
</li>
<li class="li-class">
<div class="div-list-item">
Something 3
</div>
</li>
</ul>
</div>

How can I make my left tab float left but fill the empty area to the other tabs which float right?

I have some bootstrap tabs, which align to the right inside my container:
https://jsfiddle.net/yc2dxnev/
This is the code:
<div class=container>
<ul id="tabs" class="tabs-right tabs">
<li class="banana active"><a>Banana</a></li>
<li class="monkey"><a>Monkey</a></li>
<li class="woods"><a>Woods</a></li>
</ul>
</div>
<style>
ul.tabs a {
display: block;
outline: none;
}
ul.tabs {
list-style: none;
padding: 0;
margin: 0;
display: block;
}
ul.tabs>li {
display: inline-block;
position: relative;
margin-top: 5px;
margin-bottom: -1px;
}
What I want to do is keep the tabs right and make only the left tab stick to the left, but in the same time fill the area to the next tab. It is hard to explain so I posted an image:
http://s16.postimg.org/bhr4qzt51/002.jpg
I do not know how to achieve it, maybe you know a trick.
Your right tabs should be right, so float them to the right using float:right;. Since you want to have the first list item filling the whole space, you have to put it at the end of your ul and add overflow:hidden; to it. Your code would look like this:
<div class="container">
<ul id="tabs" class="tabs-right tabs" data-tabs="tabs" style="">
<li class="monkey"><a>Monkey</a></li>
<li class="woods"><a>Woods</a></li>
<li class="banana active"><a>Banana</a></li> // move this li item to the end
</ul>
</div>
ul.tabs>li.active {
border-bottom-color: #FFF;
background-color: #FFF;
overflow:hidden;
}
.monkey, .woods{
float:right;
}
Have a look at this fiddle.

Inline Block Elements Overflowing Parent Container

I have a list of 4 menu items sitting side by side using display:inline-block;. Each item is 120px, therefore I should be able to set the parent container to be 480px wide, however this sends the last item into the next row, why is this ??
Here is a jsfiddle :http://jsfiddle.net/htdgdhxn/
My html:
<section id="nav">
<div id="nav-wrapper">
<ul id="nav-list">
<li id="nav-home">Home
</li>
<li id="nav-clothes"><a class="category All">Clothes</a>
</li>
<li id="nav-about">About Us
</li>
<li id="nav-contact">Contact Us
</li>
</ul>
</div>
</section>
CSS:
* { margin: 0px; padding: 0px; }
#nav { background-color: #fff; }
#nav-wrapper { text-align: center; height: 74px; }
#nav-list { height: 100%; width: 480px; }
#nav-list li { display: inline-block; vertical-align: top; width: 120px; height: 100%; }
#nav-list li a { text-decoration: none; color: #000; font-size: 1.6em; display: block; height: 100%; line-height: 74px; }
#nav-list li a:hover { background-color: #F0ECE1; cursor: pointer; }
I have tested and this happens in Chrome, IE and Firefox.
Remove the whitespace between each <li>
<li></li> <...space here...> <li></li>
Inline block elements create a gap between li elements.
<ul id="nav-list">
<li id="nav-home">Home
</li><li id="nav-clothes"><a class="category All">Clothes</a>
</li><li id="nav-about">About Us
</li><li id="nav-contact">Contact Us
</li>
</ul>
See fiddle
The inline-block value is incredibly useful when wanting to control margin and padding on
"inline" elements without the need to block and float them.One problem that arrises
when you use inline-block is that whitespace in HTML becomes visual space on screen.
Gross.There are a few ways to remove that space; some of them are just as gross, one is
reasonably nicer.
Solution 0: No Space Between Elements:
The only 100% solution to this issue is to not put whitespace between those elements in the HTML source code:
<ul><li>Item content</li><li>Item content</li><li>Item content</li></ul>
Solution 1: font-size: 0 on Parent
The best white-space solution is to set a font-size of 0 on the parent to the inline block
elements.
.inline-block-list { /* ul or ol with this class */
font-size: 0;
}
.inline-block-list li {
font-size: 14px; /* put the font-size back */
}
Solution 2: HTML Comments
This solution is a bit gangsta but also works. Using HTML comments as spacers between the elements works just as placing no space between elements would:
<ul>
<li>Item content</li><!--
--><li>Item content</li><!--
--><li>Item content</li>
</ul>
It might help you.
Just increase the width of your container to 500px
#nav-list { height: 100%; width: 500px; }
or remove the white spaces between consecutive li tags
or
apply display:initial in #nav-list { height: 100%; width: 480px;}
i.e #nav-list { height: 100%; width: 480px; display: initial;}
Reason:-
1. The font size of the text in the li element might be causing the problem.
You can modify it by reducing the font-size.
#nav-list li a { text-decoration: none; color: #000; font-size: 1.2em; display: block; height: 100%;line-height: 74px; }
Instead of using this
#nav-list li { display: inline-block; }
You can do like this:-
#nav-list li { display: inline; font-weight:bold;}
Please let me know if this helps.