Skip to main content

Project Study: How to Structure A "Complex" Planet Chart

I learned some basic html table elements such as <table></table>,<tr></tr>, <tb></tb>. Therefore, I can use these elements to create a simple table.

Today, I continue to learn more html table elements to add more features to a table.

<Caption>

Since we are not likely to read every detail on each website; in the other word, we like to scan content to save time.

If a web page has a table, it is better to have a title for the table. So, we can get a quick idea about this table.

Therefore, we need to add <caption></caption> element under the <table></table> directly.

screenshot from MDN Advanced Table Element


<thead>, <tbody> & <tfoot>

These three elements will help to mark up a header, body and footer section for a table. They are very useful for styling and layout.

<thead> </thead>stands for table header, which will be the first row containing the column headings.

<tbody></tbody>wrap the main body content of the table.

<tfoot> </tfoot> is the table footer, which is usually the final row of the table.

I will explain more details in the assessment example later.

Colspan, Rowspan & Scope Attributes

Some data belong to a group, so we will use "colspan" and "rowspan" attributes to make cell to span multiple columns and rows.

Scope attribute can be added to the <th> element to tell screenreaders exactly what cells the header is a header for. And, scope has two values: "rowgroup" and "colgroup". (From MDN "The scope attribute)

Now let's do a project, which requires to use the above elements and attributes to create a Planet Chart. The detail information about the assessment, relevant css code, and data is at MDN table assessment page.

Basically, we want to create a table like this:


Key points for the project:


  1. Write caption by using <caption></caption>element.
  2. Enter the table headers inside <thead></thead> element, and enter main data inside <tbody></tbody> element. Since  we need to span the cells later, so the first cell of the header row needs to be blank.

3. Once we finish all the row data, we need to use rowspan, colspan, and scope attributes to group the data.

For me, the hardest part is :


In this part, it shows that the cell" Gas giants " includes two cells: "Jupiter" and "Saturn". In order to structure the cell, we need to span the row by inserting rowspan="2" scope="rowgroup" inside <th> element. The "Ice giants" cell is spanbed the same way.

Since the cell "Jovian planet" include four rows: "Jupiter", "Saturn", "Uranus", and "Neptune". We will span the row by inserting rowspan="4" scope="rowgroup" inside <th> element.

In addition, the "Jovian planets" cell is in front of the "Jovian planets" and "Ice giants", so we put the <th rowspan="4" scope="rowgroup"> Jovian Plants </th> element on the top line.


Once we put all the relevant html correctly, the result will be:

By the way, I didn't show all the coding details here because that would be too much information. I don't want to make you feel bored and confused. You can always check the detail solution from the Planet Chart Data HTML Solution.





Comments

Popular posts from this blog

Intermediate Express.js: How To Add Styles & Partials in EJS File?

So far, we only have simple HTML tags and ejs tags in each ejs file. Every template page has no style at all. And the basic HTML header and footer are also missing. Today, I learned how to add styles and partials in ejs file. Link Style Step One: Touch a Separate CSS file I create a new directory "Style" under the "EJSDemo" directory, then I add a new CSS file "app.css" inside "Style" folder. Step Two: Add app.use(express.static()) in the app.js I add app.use(express.static("style")) in the "app.js". This will tell Express.js to serve the content of "Style" directory. Step Three: Write styles in CSS file I simple give body an orange background color and set text color to be grey. Step Four: Link to CSS file in the EJS file I just add <link> tag to link the "app.css" file on the top of the h1 tag in each ejs template. As the result, when I run the app and...

Seven Most Common jQuery Methods Last Part: ADD/REMOVE/TOGGLE CLASS()

Add, remove and toggleClass is also a very common way to manipulate style. .addClass() and .removeClass() I add two class selector in the style tag. Class one is to change text color to be green, and class two is change both text and background color.  Now I refresh the page and change h1 text to green by using addClass() method: $("h1").addClass("one") .  If you want to remove the style, you can change it to removeClass("one"). I do the same thing to the list. I change the list color and add a background color by adding the class two style value: $("li").addClass("two") . .toggleClass()  According to jQuery, toggerClass method can add or remove one or more classes from each element in the set of matched elements, depending on either the class's presence or the value of the state argument. I only want to change the first list item color and background by writing: $("li").first().toggleClas...

Intro to Backend: Is Browser The Only Place To Send HTTP Request?

Today,  I begin to learn the second part of web develop course: backend. Frontend is the stuff that we can see and interactive with, such as HTML, CSS, and JS. We can type our code, style our page, or write some function to make interaction. However, backend is everything else. For example, we type Target web address in the Internet Browser. As we hit "enter", there are a few steps to go through: 1. The HTTP request is sent to a particular server's IP address. 2. The server figures out what to send us 3. It sends a HTTP response back to us Those process we are hard to see, and it happens in less than one second. The instructor said that the browser is not the only place to send the HTTP request, and there are so many choices out there. In this learning course, we are going to use Postman App . Postman allows us to make HTTP requests and viewer responses. It is really for developers to understand how things are working or debug something. In the P...