Hello and welcome back to this tutorial series for beginners in web development with HTML & CSS.
We have been discussing form and div elements in the previous sections of this class (see class 109 part I and II).
You should have 2 files, one sections.html file and another sections.css file linked to it.
Next, we will discuss the css code we used in the sections.css, particularly 2 new attributes 'display' and 'float' .
This is the CSS code that we used to style our sections.html page.
#header{
background-color: grey;
padding-top: 5px;
padding-bottom: 5px;
padding-left: 15px;
}
h2{
margin: 0px;
color: white;
}
#content{
padding-left: 15px;
}
p{
display: inline-block;
float: left;
margin-right: 50px;
}
form{
display: inline-block;
border-left: 2px solid grey;
padding: 12px;
}
input{
display: block;
margin-bottom: 24px;
width: 200px;
padding: 8px;
}
textarea{
display: block;
margin-bottom: 24px;
width: 214px;
text-align: left;
}
button{
width: 214px;
padding: 8px;
}
#footer{
background-color: grey;
padding: 15px;
color: white;
}
ul{
list-style: none;
}
You should be familiar with all the attributes (margin, width, padding e.t.c) so far except float and display.
Let's begin with the display attribute.
As the name suggests, the display attribute is used to specify how an element of html should be seen (or not seen). It can take on many values but the following are the most commonly used ones;
To understand this further, lets do some coding.
Create an html file and name it display.html. Type the following code in it using a text editor, save and open it in your browser.
<!DOCTYPE html>
<html>
<head>
<title></title>
<link rel="stylesheet" type="text/css" href="display.css">
</head>
<body>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
<a href="#">some text 3</a>
</body>
</html>
Note : the # in href is just a placeholder (has no meaning) and so nothing happens when the link is clicked. You can even leave it empty (as in href="").
Now create a css file and name it display.css. Type the following code in it using a text editor and save it in the same location as your display.html file.
p, a{
border : 1px solid;
}
The above code simply shows a black border around our paragraphs and anchor.
Notice that even though all elements have the same content length (11 including spaces), the two paragraphs are taking the entire width of the page while the anchor is only taking the width it requires.
This is because, by default, paragraphs are block elements while anchors are inline elements.
Add the following code in your css, save and refresh your display.html page in the browser;
a{
width : 600px;
}
You will see no change. This is because the anchor element is an inline element by default, so you cannot change it's width or height unless you first modify it's display.
Modify the css code as follows;
p, a{
border : 1px solid;
}
a{
display: block;
width: 600px;
height: 600px;
}
Now save and refresh your browser. You will see that the anchor element now takes a larger space (600px by 600px to be exact). This is because you have modified the display of the a tag to make it a block element.
Now modify the css as follows;
p, a{
border : 1px solid;
width: 200px;
height: 100px;
}
a{
display: block;
}
p{
display: inline-block;
}
We have given the same size (width & height) to all the elements, and changed the display of the paragraph to inline-block.
Save and refresh display.html in your browser.
Notice how now the paragraphs appear next to each other.
Why is the anchor not appearing next to the paragraphs? Why is has it started on it's own line even though it has the same width as the paragraphs?
This is because the anchor's display is block. Remember a block element will start on it's own line and will not allow another element in that line even if there is space available.
Now modify the css as follows;
p, a{
display: inline-block;
border : 1px solid;
width: 200px;
height: 100px;
}
Save the changes (we have made all elements to be inline-block elements). Refresh your browser and observe how all elements appear next to each other.
The display property can be a bit tricky to get at first, so be sure to play around with your code, re-read this blog in order to grasp the concept.
As always, I will upload a video soon that you can use to follow up, and the comment section below is available if you have any questions/feedback.
Happy coding, we'll catch up later in 4th and final part of this class, where we shall discuss the float property.
We have been discussing form and div elements in the previous sections of this class (see class 109 part I and II).
You should have 2 files, one sections.html file and another sections.css file linked to it.
Next, we will discuss the css code we used in the sections.css, particularly 2 new attributes 'display' and 'float' .
This is the CSS code that we used to style our sections.html page.
#header{
background-color: grey;
padding-top: 5px;
padding-bottom: 5px;
padding-left: 15px;
}
h2{
margin: 0px;
color: white;
}
#content{
padding-left: 15px;
}
p{
display: inline-block;
float: left;
margin-right: 50px;
}
form{
display: inline-block;
border-left: 2px solid grey;
padding: 12px;
}
input{
display: block;
margin-bottom: 24px;
width: 200px;
padding: 8px;
}
textarea{
display: block;
margin-bottom: 24px;
width: 214px;
text-align: left;
}
button{
width: 214px;
padding: 8px;
}
#footer{
background-color: grey;
padding: 15px;
color: white;
}
ul{
list-style: none;
}
You should be familiar with all the attributes (margin, width, padding e.t.c) so far except float and display.
Let's begin with the display attribute.
As the name suggests, the display attribute is used to specify how an element of html should be seen (or not seen). It can take on many values but the following are the most commonly used ones;
- none => when display is specified as none, the element will not be visible. It is completely removed.
- inline => when display is specified as inline, the element takes as much space (width & height) as it requires. You cannot change the width and height of an element after specifying it as inline.
- inline-block => when display is specified as inline-block, the element takes as much space (width & height) as it requires but you can change this width and height.
- block => when display is specified as block, the element takes the whole width and starts in a new line.
To understand this further, lets do some coding.
Create an html file and name it display.html. Type the following code in it using a text editor, save and open it in your browser.
<!DOCTYPE html>
<html>
<head>
<title></title>
<link rel="stylesheet" type="text/css" href="display.css">
</head>
<body>
<p>Paragraph 1</p>
<p>Paragraph 2</p>
<a href="#">some text 3</a>
</body>
</html>
Note : the # in href is just a placeholder (has no meaning) and so nothing happens when the link is clicked. You can even leave it empty (as in href="").
Now create a css file and name it display.css. Type the following code in it using a text editor and save it in the same location as your display.html file.
p, a{
border : 1px solid;
}
The above code simply shows a black border around our paragraphs and anchor.
Notice that even though all elements have the same content length (11 including spaces), the two paragraphs are taking the entire width of the page while the anchor is only taking the width it requires.
This is because, by default, paragraphs are block elements while anchors are inline elements.
Add the following code in your css, save and refresh your display.html page in the browser;
a{
width : 600px;
}
You will see no change. This is because the anchor element is an inline element by default, so you cannot change it's width or height unless you first modify it's display.
Modify the css code as follows;
p, a{
border : 1px solid;
}
a{
display: block;
width: 600px;
height: 600px;
}
Now save and refresh your browser. You will see that the anchor element now takes a larger space (600px by 600px to be exact). This is because you have modified the display of the a tag to make it a block element.
Now modify the css as follows;
p, a{
border : 1px solid;
width: 200px;
height: 100px;
}
a{
display: block;
}
p{
display: inline-block;
}
We have given the same size (width & height) to all the elements, and changed the display of the paragraph to inline-block.
Save and refresh display.html in your browser.
Notice how now the paragraphs appear next to each other.
Why is the anchor not appearing next to the paragraphs? Why is has it started on it's own line even though it has the same width as the paragraphs?
This is because the anchor's display is block. Remember a block element will start on it's own line and will not allow another element in that line even if there is space available.
Now modify the css as follows;
p, a{
display: inline-block;
border : 1px solid;
width: 200px;
height: 100px;
}
Save the changes (we have made all elements to be inline-block elements). Refresh your browser and observe how all elements appear next to each other.
The display property can be a bit tricky to get at first, so be sure to play around with your code, re-read this blog in order to grasp the concept.
As always, I will upload a video soon that you can use to follow up, and the comment section below is available if you have any questions/feedback.
Happy coding, we'll catch up later in 4th and final part of this class, where we shall discuss the float property.
Comments
Post a Comment