Before we continue with our project, we should know a bit about Flex.
Flex stands for Flexible Box Layout. In flex we arrange elements relative to each other either horizontally or vertically. The best example of flex is youtube.
data:image/s3,"s3://crabby-images/83e66/83e6659fb457591a32db08e03e825aa64887fc13" alt=""
Though we can arrange them without using flex as well, but flex helps to arrange these elements smoothly in a better way and with lesser code.
Flex Direction
The default direction of flex is Horizontal(row).
So as to understand this let’s create a bigger div and 4 smaller div inside that parent div and give them some colors.
data:image/s3,"s3://crabby-images/45e2a/45e2a121cfc628c458499c6ab1b69e71f058f2b4" alt=""
data:image/s3,"s3://crabby-images/930e7/930e7e7bb9e8d7378082801815ea51833e332dbe" alt=""
data:image/s3,"s3://crabby-images/6310c/6310c1e4b9de3749c0be2f640b4a6d294d740acd" alt=""
In order to change flex direction, we can change that using property flex-direction: column.
If we want to place the child div from right to left, then we can use the property value as row-reverse.
Question: What if we want to place the div’s in below order Div2, Div3, Div1, Div4, means in the order we want ?
For that we can set the property order to the child div explicitly. By default the order value is 0.
data:image/s3,"s3://crabby-images/d4613/d4613d4331804db0370c8fe029963c39b6ee461d" alt=""
data:image/s3,"s3://crabby-images/f602e/f602eecd5015821b5273e53d4f244fa46fcab573" alt=""
Flex Wrap
data:image/s3,"s3://crabby-images/fbc8a/fbc8afce0675a350bef1d1e66ffcd37437cfc592" alt=""
data:image/s3,"s3://crabby-images/75ef3/75ef3c5b3428441876f1777e605b7c4a6a21516f" alt=""
Let’s try to add one more div and see what happens
data:image/s3,"s3://crabby-images/18e35/18e3597c880466699ab34cba5625c50221b3bf6d" alt=""
Though the height and width was set to 200px, 200px. On adding a new div, the width has reduced and div’s have adjusted themselves.
If we want the div’s should be displayed as per the height defined, then we need to use flex-wrap property.
Default value of flex-wrap property is no-wrap.
data:image/s3,"s3://crabby-images/2cb6a/2cb6ac8fc0aa8d5af6c6e4b4c45b3bf3ac312f71" alt=""
data:image/s3,"s3://crabby-images/a604a/a604a5ccf7a5832999e675cc05d1f0aa7850a2fa" alt=""
data:image/s3,"s3://crabby-images/541fd/541fd7da8678b6bc9887109a587d6f2fc385f8bd" alt=""
data:image/s3,"s3://crabby-images/c2c26/c2c261b30bf4f725886702f3748f1d959acf9dd8" alt=""
data:image/s3,"s3://crabby-images/4229a/4229a9368ff9fcd62574276e8a87f5e185395041" alt=""
data:image/s3,"s3://crabby-images/938ff/938ffcf65db3d2397fa7a5a9dc0c0032492523fa" alt=""
Flex Grow And Flex Shrink
Let’s make some change in the html and css code. Just keeping 2 div and reducing the value of the parent div so as to understand this concept.
data:image/s3,"s3://crabby-images/f3a79/f3a79780452e814ef8dcda296367f7b83dc8b53b" alt=""
data:image/s3,"s3://crabby-images/07537/07537825e1ca3cadec23aa0ba1aea7b384d86499" alt=""
data:image/s3,"s3://crabby-images/6b0f5/6b0f5982b950e293355529bf1e3d0361fc5abb3f" alt=""
As the child div as 200px,200px and the parent div is 500px. There is a remaining of 100px available.
If we want that the child div should adjust accordingly to occupy the whole parent div, then we can use the property flex-grow.
data:image/s3,"s3://crabby-images/19647/196476b64c5c4dd35d1bfe04b625cff5ec93f2d1" alt=""
data:image/s3,"s3://crabby-images/c921e/c921e69c2597425ae2f207710e1b1a60d220bb95" alt=""
Now so as to understand the concept of flex-shrink, let’s reduce the width to 300px from parent div
data:image/s3,"s3://crabby-images/cffae/cffaed5bdcf3ac023a83183170a6133ad071ab16" alt=""
By default the div’s will distribute equally. Let’s implement flex-shrink property where we will deduct 80% from the div1.
data:image/s3,"s3://crabby-images/1f3a1/1f3a17086df9e11ffb52ecef03f3834e759eb56a" alt=""
data:image/s3,"s3://crabby-images/a93ba/a93ba56c93b0278e8fc30b5b34f3c5e8718543b9" alt=""
Flex Justify Content
Let’s just directly jump into the practical
data:image/s3,"s3://crabby-images/b374e/b374ee64fd18337b50cc35b58b8907853ae346b9" alt=""
data:image/s3,"s3://crabby-images/79ab5/79ab5758a81be21397f53f8ca6115b8144fd1adc" alt=""
data:image/s3,"s3://crabby-images/86ce3/86ce30dfd072fd93887dd7b254e4e2534e1e8dc9" alt=""
data:image/s3,"s3://crabby-images/22329/223296023a9f7c34c217e04c766a32f55958fe4b" alt=""
data:image/s3,"s3://crabby-images/fb1ce/fb1ce273138b7ff7cf9253e97cdcf46cb8a80999" alt=""
data:image/s3,"s3://crabby-images/941c6/941c69cc1f373ab03fe36e4171adf11beb10e40c" alt=""
Align Content
It is used to align the elements across the cross axis. For example
data:image/s3,"s3://crabby-images/4e416/4e4164501af4a28b9a1313e88c0957140740cf48" alt=""
Let’s understand this with help of an example.
data:image/s3,"s3://crabby-images/b9184/b9184aa847f4586d15d3bd5088b48538f7969cdc" alt=""
data:image/s3,"s3://crabby-images/ccbd7/ccbd7cea376ce8d0cab6c53d7bafe36486770b25" alt=""
align-items: flex-start;
data:image/s3,"s3://crabby-images/fb892/fb892dc1c2a67701fe5dd6bc1412ee7347f30901" alt=""
align-items: flex-end;
data:image/s3,"s3://crabby-images/1ab4a/1ab4a54f008658b32f61dc9abe0cc73f402f9d49" alt=""
align-items: center;
data:image/s3,"s3://crabby-images/6bafe/6bafe6fccb550973a6183b1f857bf55eb52a30a6" alt=""
flex-direction: row;
align-items: stretch;
#container div{
height: auto;
width: 100px;}
We can set max/min height as well.
data:image/s3,"s3://crabby-images/f3382/f338235d4404df50a854938cef201ac64beff709" alt=""
data:image/s3,"s3://crabby-images/a61a6/a61a64bce80ba32110961b8c2cfcd147b0eba365" alt=""
Let’s see the last one which is baseline. Let’s include margin so as to understand this.
data:image/s3,"s3://crabby-images/74cc7/74cc752ba8264ae138a19470f5c86a566111b010" alt=""
data:image/s3,"s3://crabby-images/9c372/9c372f4de0511a90473246af188eb704e81928c7" alt=""
data:image/s3,"s3://crabby-images/47265/47265063bf118729d65777f8fa9d0d91b1bc5557" alt=""
Project
Converting Resume Code to Flex
Skills, education, portfolio, contact section would be in a form of flex. Let’s make that change.
data:image/s3,"s3://crabby-images/46ab4/46ab489f05dcad8e127f8f998ead8452b15ef588" alt=""
So as to see the sections with different color let’s set height as 75vh and later we can change that.
data:image/s3,"s3://crabby-images/9d911/9d91100710b39a1dc55a59f6244ec3ff33192d71" alt=""
data:image/s3,"s3://crabby-images/63ba8/63ba87bfa479f6d075808a2203da97d25895bc78" alt=""
Skills Section
Let’s create html for this first.
data:image/s3,"s3://crabby-images/3f163/3f1636898b738b4206253f605400721edd835ea6" alt=""
data:image/s3,"s3://crabby-images/f7032/f7032c081468dac4cf8ddf00e2c37e9b7311c3e5" alt=""
Let’s jump onto the css part of the above code
Now let’s display the skills in form of a bar %. Let’s create a HTML for the same.
data:image/s3,"s3://crabby-images/5862b/5862b01696b34121a75f9435dd9c6eedd0250681" alt=""
data:image/s3,"s3://crabby-images/5c293/5c29305fbba65d1eca53499b11baf05812063908" alt=""
data:image/s3,"s3://crabby-images/6f5f0/6f5f09e162a06c63fde164c84aeabbfe11e7247c" alt=""
Let’s align the div in center.
data:image/s3,"s3://crabby-images/454f1/454f147ca8c2e85e4dfdb055593b8194e0f312d4" alt=""
data:image/s3,"s3://crabby-images/315e5/315e5b34ad01acb947cb68df70ecc015ef8eb2e9" alt=""
Let’s modify our skills display section as per our need.
data:image/s3,"s3://crabby-images/82521/825218ea72c5abe155da8b89676251a1f8b6d9aa" alt=""
Let’s create the skills tab now
In this we will have a parent div with color grey and a child div with some other color which will indicate the percent of that particular skill.
Here is the HTML code for one skill
data:image/s3,"s3://crabby-images/cbbfc/cbbfc01ac62d09692644dd433377bc963daad336" alt=""
Now let’s write relevant CSS code for this skill
data:image/s3,"s3://crabby-images/849ad/849ad84f19b89ceedfac8526a41ffb9d28f42d13" alt=""
data:image/s3,"s3://crabby-images/148d8/148d856370c298c33db3bbc72c222f428644db65" alt=""
Similarly we will add the remaining of the skills.
data:image/s3,"s3://crabby-images/9cfbd/9cfbd951fd4ad99b0de385356115ac188b4283ab" alt=""
data:image/s3,"s3://crabby-images/fa323/fa323d25932dc0e3f7a22c0b21acaff1d312336a" alt=""