<table>
Kolejnym sposobem prezentowania i grupowania danych w języku Html jest tabela. Sposób prezentowania danych w tabeli html jest taki sam jak w każdej innej tabeli, którą znamy z życia codziennego.Tabele tworzymy przy użyciu elementu <table>
.
<table> </table>
<tr>
Jednak, żeby tabela powstała, musimy do niej dodać jeszcze wiersze oraz umieścić tam komórki. Wiersze do tabeli dodajemy poprzez element <tr>
(ang. table row – wiersz tabeli).
<table> <tr></tr> </table>
<td>
Żeby nasza tabela była kompletna i poprawnie wyświetlała dane, należy jeszcze dodać do niej komórki. Komórki tabeli dodajemy poprzez element <td>
(ang. table data, table cell – dane tabeli, komórka tabeli). Do rozwijania skrótu td powszechnie używa się table cell, jednak nazwa pochodzi od table data.
<table> <tr> <td>Treść</td> </tr> </table>
Treść |
Jeszcze jedna uwaga. Na ekranie nie pokaże się wam taka ramka, gdyż wszystkie tabele na tej stronie zostały lekko sformatowane przy użyciu CSS, aby ułatwić wam zrozumienie i poznanie tabeli w html. Formatowania tabel przy użyciu CSS, będziemy się uczyć na kolejnym kursie poświęconym w całości formatowaniu przy użyciu języka CSS.
Treść umieszczamy zawsze w elemencie <td>
. Element ten podobny jest trochę do kolumny. Jednak nie zapisujemy jej raz tak jak ma to miejsce w przypadku wiersza, tylko musimy za każdym razem dodać tyle komórek (kolumn) do wiersza ile aktualnie nam potrzeba.
<table> <tr> <td>1 wiersz 1 kolumna</td> <td>1 wiersz 2 kolumna</td> </tr> <tr> <td>2 wiersz 1 kolumna</td> <td>2 wiersz 2 kolumna</td> </tr> </table>
1 wiersz 1 kolumna | 1 wiersz 2 kolumna |
2 wiersz 1 kolumna | 2 wiersz 2 kolumna |
<th>
Mamy już treść tabeli. Przydałoby się jeszcze oznaczyć czego dotyczą nasze dane. W tym celu posłużymy się nagłówkiem tabeli. Nagłówek taki uzyskujemy poprzez zastosowanie elementu <th>
(ang. table heading). Element ten stosujemy tak jak zwykłą komórkę tabeli, czyli <td>
. Nagłówki również umieszczamy w wierszach tabeli, czyli elementach <tr>
.
<table> <tr> <th>Nagłówek kolumny</th> </tr> <tr> <td>wiersz</td> </tr> </table>
Nagłówek kolumny |
---|
wiersz |
<table> <tr> <th></th> <th>Nagłówek kolumny</th> </tr> <tr> <th>Nagłówek Wiersza</th> <td>wiersz</td> </tr> </table>
Nagłówek kolumny | |
---|---|
Nagłówek Wiersza | wiersz |
scope
Do naszego nagłówka tabeli warto dodać atrybut scope
(zasięg), który informuje nas, którego zakresu danych. dany nagłówek dotyczy. Wartość atrybutu scope
dla kolumn to col
.
<table> <tr> <th scope="col">Nagłówek kolumny</th> </tr> <tr> <td>wiersz</td> </tr> </table>
Nagłówek kolumny |
---|
wiersz |
Skoro oznaczyliśmy już kolumny nagłówkami tabeli, warto by oznaczyć również nasze wiersze. Dodamy również atrybut scope
do nagłówków wierszy i przyjmie on wartość row
(wiersz). W pierwszym wierszu dodamy najpierw pusty element, żeby przesunąć nagłówki kolumn na właściwe miejsce.
<table> <tr> <th></th> <th scope="col">Nagłówek kolumny</th> </tr> <tr> <th scope="row">Nagłówek wiersza</th> <td>wiersz</td> </tr> </table>
Nagłówek kolumny | |
---|---|
Nagłówek wiersza | wiersz |
Jak widzicie prawidłowe poskładanie tabeli wymaga nie lada wyobraźni przestrzennej, gdyż pogubić się w tych wszystkich wierszach, kolumnach i nagłówkach nie jest trudno.
W przypadku, gdy jedna komórka odnosi się do więcej niż jednego nagłówka, możemy dokonać połączenia kilku komórek w jedną, żeby kilkukrotnie nie powtarzać jej wartości. Łączenie nie jest jednak najlepszym określeniem, w przypadku tabeli html. W zasadzie nie dokonujemy łączenia komórek, a zwiększenia ich rozpiętości w pionie lub poziomie.
colspan
W celu zwiększenia rozpiętości poziomej komórki używamy atrybutu colspan
(ang. column span – rozpiętość kolumnowa komórki). Atrybut ten przyjmuje wartości liczbowe, tzn. przekazujemy tam jaką rozpiętość kolumnową (czyli w poziomie) ma posiadać dana komórka tabeli.
colspan
<table> <tr> <th></th> <th>Poniedziałek</th> <th>Wtorek</th> </tr> <tr> <th>18:00</th> <td>Kręgle</td> <td>Polo</td> </tr> <tr> <th>20:00</th> <td colspan="2">Basen i Sauna</td> </tr> </table>
Poniedziałek | Wtorek | |
---|---|---|
18:00 | Kręgle | Polo |
20:00 | Basen i Sauna |
colspan i scope
<table> <tr> <th></th> <th scope="col">Poniedziałek</th> <th scope="col">Wtorek</th> <th scope="col">Środa</th> <th scope="col">Czwartek</th> <th scope="col">Piątek</th> </tr> <tr> <th scope="row">18:00</th> <td>Kręgle</td> <td>Polo</td> <td colspan="2">Golf</td> <td>Krykiet</td> </tr> <tr> <th scope="row">20:00</th> <td colspan="4">Basen i Sauna</td> <td>Impreza</td> </tr> </table>
Poniedziałek | Wtorek | Środa | Czwartek | Piątek | |
---|---|---|---|---|---|
18:00 | Kręgle | Polo | Golf | Krykiet | |
20:00 | Basen i Sauna | Impreza |
rowspan
Rozpiętość komórek możemy podawać nie tylko w poziomie, ale również w pionie, łącząc kolejne wiersze. W tym celu posłużymy się atrybutem rowspan
(ang. row span – rozpiętość wierszowa komórki). Atrybut ten działa analogicznie do poprzedniego, tylko tym razem zwiększając rozpiętość komórki w pionie.
rowspan
<table> <tr> <th></th> <th>Rodzaj</th> </tr> <tr> <th>Sharknado</th> <td rowspan="3">Horror</td> </tr> <tr> <th>Shartopussy</th> </tr> <tr> <th>Piranha 3DD</th> </tr> </table>
Rodzaj | |
---|---|
Sharknado | Horror |
Shartopussy | |
Piranha 3DD |
rowspan i scope
<table> <tr> <th></th> <th scope="col">Rodzaj</th> <th scope="col">Główny bohater</th> <th scope="col">Krótki opis</th> </tr> <tr> <th scope="row">Sharknado</th> <td rowspan="3">Horror</td> <td>Rekin</td> <td>Wirujące szczęki</td> </tr> <tr> <th scope="row">Sharktopussy</th> <td>Zmutowany rekin</td> <td>Macki, dużo macek</td> </tr> <tr> <th scope="row">Piranha 3DD</th> <td>Pirania</td> <td>Ostre rwanie</td> </tr> </table>
Rodzaj | Główny bohater | Krótki opis | |
---|---|---|---|
Sharknado | Horror | Rekin | Wirujące szczęki |
Sharktopussy | Zmutowany rekin | Macki, dużo macek | |
Piranha 3DD | Pirania | Ostre rwanie |
Każdą tabele można podzielić na trzy sekcje, które definiują nagłówek, ciało, a także stopkę tabeli. Taki podział może przydać się nam przy formatowaniu tabeli, gdy będziemy do niej dodawać zasady CSS. Jednak nie jest on konieczny do wprowadzenia. Jest to raczej kwestia semantyczna.
<thead>
Sekcję nagłówkową oznaczymy elementem <thead>
(ang. table head – sekcja nagłówkowa tabeli). Ten element przyda nam się przy oznaczaniu nazw kolumn przy użyciu elementu <th>
.
<tbody>
W tzw. ciele tabeli znajdzie się jej główna treść, te nasze dane właściwe. Ciało tabeli oznaczymy elementem <tbody>
(ang. table body – ciało tabeli).
<tfoot>
Dane podsumowujące tabelę mogą znaleźć się w stopce tabeli. Sekcję tą oznaczymy elementem <tfoot>
(ang. table footer – stopka tabeli).
<table> <thead> <tr> <th scope="col">Rok</th> <th scope="col">Przychody</th> <th scope="col">Koszty</th> <th scope="col">Zysk</th> </tr> </thead> <tbody> <tr> <th scope="row">2013</th> <td>200'000</td> <td>150'000</td> <td>50'000</td> </tr> <tr> <th scope="row">2014</th> <td>500'000</td> <td>300'000</td> <td>200'000</td> </tr> </tbody> <tfoot> <tr> <th scope="row">Razem</th> <td>700'000</td> <td>450'000</td> <td>250'000</td> </tr> </tfoot> </table>
Rok | Przychody | Koszty | Zysk |
---|---|---|---|
2013 | 200’000 | 150’000 | 50’000 |
2014 | 500’000 | 300’000 | 200’000 |
Razem | 700’000 | 450’000 | 250’000 |
To by było na tyle z tabel, jeśli chodzi o czysty html.
>>>Dalej<<<