Course
Lists
CSS Tutorial
This CSS tutorial is designed for beginners to navigate through the essentials and intricate aspects of CSS styling. Upon finishing this tutorial, participants will possess a comprehensive understanding of CSS, setting a solid foundation for further exploration and mastery. This guide aims to equip you with the skills necessary to transform your visions into visually appealing web designs, laying the groundwork for your journey towards becoming an accomplished web designer.
Lists
Lists are useful as they present the information in a structured and organized manner. Lists improve the readability and comprehension of content on a web page. So, if the content is listed, it is easy to follow.
Lists are commonly used to display items, steps, options, or any other type of related information that should be presented sequentially or in a group.
This chapter will discuss how to control list type, position, style, etc., using CSS. Before that let us understand how are HTML lists different in the following sections.
HTML Lists
HTML provides mainly two kinds of lists - <ol> (ordered list) and <ul> (unordered list).
Example
Let us see an example of the two kinds of lists (without CSS):
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> h2 {margin-bottom: 5px;} </style> </head> <body> <div> <h2>Ordered list</h2> <ol class="list"> <li>The list is ordered.</li> <li>It is used in cases where we need to follow a sequence.</li> <li>The points are numbered.</li> </ol> <h2>Unordered list</h2> <ul class="list"> <li>The list is unordered.</li> <li>It is used in cases where we need not follow a sequence.</li> <li>The points are bulleted.</li> </ul> </div> </body></html>
Lists - CSS Properties
CSS provides a set of properties that can be applied to any list, which are as follows:
- The list-style-type allows you to control the shape or appearance of the marker.
- The list-style-position specifies whether a long point that wraps to a second line should align with the first line or start underneath the start of the marker.
- The list-style-image specifies an image for the marker rather than a bullet point or number.
- The list-style serves as shorthand for the preceding properties.
Item markers for lists or Bullet Styles
To change the type of marker used for a list’s items, property list-style-type can be used. The same property can be used for both ordered and unordered lists.
Let us see an example:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> h2 { margin-bottom: 5px; } ol.o1 { list-style-type: lower-roman; } ol.o2 { list-style-type: upper-alpha; } ul.u1 { list-style-type:square; } ul.u2 { list-style-type: circle; } </style> </head> <body> <div> <h2>Ordered list - Item markers</h2> <ol class="o1"> <li>The item marker is lower-roman.</li> <li>It is used in cases where we need to follow a sequence.</li> </ol> <ol class="o2"> <li>The item marker is upper-alpha.</li> <li>It is used in cases where we need to follow a sequence.</li> </ol> <h2>Unordered list - Item markers</h2> <ul class="u1"> <li>The item marker is square.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> <ul class="u2"> <li>The item marker is circle.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> </div> </body></html>
Following table lists possible values that can be used for property list-style-type:
The list-style-type property, as well as all other list-related properties, can be applied only to an element that has a display of list-item, but CSS doesn’t distinguish between ordered and unordered list items. User agent may prohibit ordered markers from being applied to unordered lists, and vice versa. You can’t count on this, so be careful.
Item list marker - an image (Using a custom bullet image)
You might prefer to use an image as an item list marker. The list-style-image property can be used to to specify an image as an item list marker.
You can use your own bullet style. If no image is found, then default bullets are returned.
Syntax
ul { list-style-image: url('URL') }
Let us see an example:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> h2 { margin-bottom: 5px; } div { padding: 5px; margin-left: 100px;} ul { list-style-image: url('/images/bullet.gif') } </style> </head> <body> <div> <h2>Unordered list - Image as item marker</h2> <ul> <li>The item marker is square.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> <ul> <li>The item marker is circle.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> </div> </body></html>
Points to remember:
- It is advisable to provide an alternative for an image as list marker, so that in case of image not getting loaded or gets corrupted, the user is having a fallback option.
- Syntax:
- ul { list-style-image: url('URL'); list-style-type: circle / square; }
- In case you don't want the image to be marker for the nested list, specify the list-style-image: none for the nested list items.
- Syntax:
- ul { list-style-image: url('URL'); list-style-type: circle / square; }ul ul { list-style-image: none; }
The above points are demonstrated in the following example:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> h2 { margin-bottom: 5px; } div { padding: 5px; margin-left: 100px;} ul { list-style-image: url('/images/bullet.gif') } ul ul { list-style-image: none; } </style> </head> <body> <div> <h2>Unordered list - Image as item marker</h2> <ul> <li>The item marker is an image.</li> <li>It is used in cases where we need use images. <ul> <li>The item marker is a circle.</li> <li>this demonstrates skipping image marker for sub item list.</li> </ul> </li> </ul>
</div> </body></html>
The list item marker - Position or Bullet position
The list-style-position property indicates whether the marker should appear inside or outside of the box containing the bullet points. It can have one of the following values −
Let us see an example below with the padding removed from the lists and a left red border added:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> body { padding-left: 50px; }
ul:nth-of-type(1) { list-style-position: inside; padding: 0; border-left: solid 2px red; }
ul:nth-of-type(2) { list-style-position: outside; padding: 0; border-left: solid 2px red; } </style> </head> <body> <h2>List style position</h2> <div> <ul style = "list-style-type:circle; list-style-position:outside;"> <li>The item marker is circle, with style position as outside. Let us see where the bullet is lying.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> </div> <div> <ul style = "list-style-type:square; list-style-position:inside;"> <li>The item marker is square, with style position as inside. Let us see where the bullet is lying.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> </div> </body></html>
list-style - Shorthand Property
The list-style allows you to specify all the three list properties into a single expression.
Following are the values that list-style can hold:
- <list-style-type>
- <list-style-image>
- <list-style-position>
Points to remember:
- The order of the values passed to the list-style is not fixed.
- Any of the three values can be omitted.
- If any of the value(s) is missing, it will be filled by the default value for the same. But there has to be minimum one value passed.
Let us see an example:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> div { border: 2px solid; width: 500px;} </style> </head> <body> <h2>List style - shorthand</h2> <h3>Three values passed</h3> <ul style = "list-style: url('C:/WORK/CSS/tp-css/images/try-it.jpg') circle outside;"> <li>The item marker is an image, position as outside. In absence of image, the marker will be a circle. Try not loading the image and see the type as circle.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul>
<h3>Two values passed</h3> <ul style = "list-style: square inside"> <li>The item marker is square, with style position as inside and no image.</li> <li>It is used in cases where we need not follow a sequence.</li> </ul>
<h3>One value passed</h3> <ul style = "list-style: disc"> <li>The item marker is disc, with style position as outside (default) and no image (default - none).</li> <li>It is used in cases where we need not follow a sequence.</li> </ul> </body></html>
Controlled list counting
At time we might want to count differently on an ordered list — e.g., starting from a number other than 1, or counting backwards, or counting in steps of more than 1. HTML and CSS have some tools to help you here.
start
The start attribute allows you to start the list counting from a number other than 1 as demonstared in the following example:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
</head> <body> <h2>Controlled counting using start</h2> <ol start="4"> <li>Java.</li> <li>HTML.</li> <li>CSS.</li> <li>React.</li> </ol> </body></html>
reversed
The reversed attribute will start the list counting reverse or down instead of up as demonstared in the following example:
<!DOCTYPE html> <html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
</head> <body> <h2>Controlled counting using start</h2> <ol start="4" reversed> <li>Java.</li> <li>HTML.</li> <li>CSS.</li> <li>React.</li> </ol> </body> </html>
value
The value attribute allows you to set your list items to specific numerical values, as demonstared in the following example:
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0">
</head> <body> <h2>Controlled counting using start</h2> <ol start="4" reversed> <li value="2">Java.</li> <li value="3">HTML.</li> <li value="1">CSS.</li> <li value="4">React.</li> </ol> </body></html>
Styling lists with colors
We can make lists look more stylish and colorful using some styling as demonstared in the following example. As we see any styling added to the <ul> or <ol> tag will affect the entire list, whereas the addition to the individual <li> tag will affect only the items of the corresponding list.
<!DOCTYPE html><html> <head> <title>CSS - Lists</title> <meta charset="UTF-8"> <meta http-equiv="X-UA-Compatible" content="IE=edge"> <meta name="viewport" content="width=device-width, initial-scale=1.0"> <style> ol{ list-style: upper-latin; background: Aquamarine; padding:20px; } ol li{ background: silver; padding:10px; font-size:20px; margin:10px; } ul{ list-style: square inside; background: teal; padding:20px; } ul li{ background: olive; color:white; padding:10px; font-size:20px; margin:10px; } </style> </head> <body> <h2>Controlled counting using start</h2> <ol> <li>Java.</li> <li>HTML.</li> <li>CSS.</li> <li>React.</li> </ol> <ul> <li>Java.</li> <li>HTML.</li> <li>CSS.</li> <li>React.</li> </ul> </body></html>
Print Page