タブは、ページの一部分のコンテンツを切り替えるときに有効なUIです。タプを使うことで、画面全体を遷移する必要がないためユーザーの負担を減らすことができます。プは、開いている状態と閉じている状態があります。
タブとは?
タブは引き出しのように必要な情報を出し入れすることができ、すべてのコンテンツを一度に表示する必要がない時に有効ですが、デメリットとしてそれぞれのタブの中の情報を同時に表示することはできない為、情報を比較する必要がある場合には不向きです。
はじめに開いているタブはユーザーがアクションする前から表示されますが、閉じているタブはユーザーがクリックしなければ見ることができません。
そのため、タブの中の情報をタイトルで判断することになります。タブを使うことによって、一度に全ての情報を表示するよりも見つけづらくならないように分かりやすいタイトルを付けましょう。
さらに、はじめに開いているタブの情報はユーザーにとって関心の高いものにします。タブは多くのWebサイトで利用されているため、ユーザーにとって「クリックすることで、選択した項目に切り替わる」という挙動がイメージしやすいことも利点です。
タブをデザインする時の3つのポイント
タブはUIの中でも、地味で面白みのない一面のように見えるかもしれませんが、きちんとタブの機能や役割を理解してデザインすることによって、ユーザーの混乱を防ぎ、ユーザーもストレスなく必要な情報を受け取ることができます。
以下3つはデザインする上で注意しましょう。
タブの数とタイトルのサイズに配慮する
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されていますが、スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界で、それ以上の場合は、タブUIのメリットである見出しの一覧性が失われてしいます。
また、タブのタイトルの可読性も重要で、タイトルが読みやすいテキストサイズを心がけましょう。
タブは一列にする
タブの数は並列にべられる数にします。
タブをの数を1列以上にしてしまうと、1列目のタブとコンテンツが離れてしまいタブと認識できなくなることで、ユーザーが情報を見落としてしまう可能性があるります。
1列に収まりきらないようなタブは、情報設計を見直す必要があるでしょう。
パネルの最上部にタブバーを設置
ユーザーは、コンテンツを見る時に上から順に内容を見ていく為、タブバーは最上部に設置してまず一番最初に見える位置にメニューを配置することで、構成や目次を見やすくします。
また、ユーザーが現在地を把握できるよう、色を付けたり、アンダーラインを引いたりして、表示中のタブを目立たせましょう。
HTMLとCSSのコピペでできるタブのUI
タブは見慣れたUIで、そこに何か特別な意味があるようには感じられないかもしれませんが、とても効率よく情報を提供することができます。
以下はjsを使わないHTMLとCSSのコピペでできるタブです。
Tab 1
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。
Tab 2
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。
Tab 3
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。
Tab 4
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。
コードを表示する
<section class="tabs">
<input id="tab-1" type="radio" name="radio-set" class="tab-selector-1" checked="checked" />
<label for="tab-1" class="tab-label-1">Tab 1</label>
<input id="tab-2" type="radio" name="radio-set" class="tab-selector-2" />
<label for="tab-2" class="tab-label-2">Tab 2</label>
<input id="tab-3" type="radio" name="radio-set" class="tab-selector-3"/>
<label for="tab-3" class="tab-label-3">Tab 3</label>
<input id="tab-4" type="radio" name="radio-set" class="tab-selector-4"/>
<label for="tab-4" class="tab-label-4">Tab 4</label>
<!--<div class="clear-shadow"></div>-->
<div class="content">
<div class="content-1">
<p class="content-title">Tab 1</p>
<p>タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。</p>
</div>
<div class="content-2">
<p>Tab 2</p>
<p>タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。 </p>
<p>
タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。</p>
</div>
<div class="content-3">
<p>Tab 3</p>
<p>タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。</p>
</div>
<div class="content-4">
<p>Tab 4</p>
<p>タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。タブは、PCサイトだけでなくスペースに限りのあるスマートフォンサイトでも頻繁にも利用されています。スマートフォンサイトの場合には、ボタンと同様に指でタップできる十分なサイズが必要なため、タブの数は3つから5が限界になります。また、タブのタイトルの可読性も重要になります。タイトルが読みやすいテキストサイズを心がけましょう。</p>
</div>
</div>
</section>
.tabs {
position: relative;
margin: 20px auto;
width: 1024px;
max-width: 100%;
overflow: hidden;
padding-top: 10px;
margin-bottom: 60px;
filter: drop-shadow(2px 10px 10px rgba(0,0,0,0.3));
}
.tabs input {
position: absolute;
z-index: 1000;
width: 25%;
height: 50px;
left: 0;
top: 0;
opacity: 0;
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=0)";
filter: alpha(opacity=0);
cursor: pointer;
margin: 0;
}
.tabs input#tab-2 {
left: 25%;
}
.tabs input#tab-3 {
left: 50%;
}
.tabs input#tab-4 {
left: 75%;
}
.tabs label {
background: #4f96f6;
color: #fefefe;
font-size: 15px;
line-height: 50px;
height: 60px;
position: relative;
top: 0;
padding: 0 20px;
float: left;
display: block;
width: 25%;
letter-spacing: 1px;
text-transform: uppercase;
font-weight: bold;
text-align: center;
box-shadow: 2px 0 2px rgba(0, 0, 0, 0.1), -2px 0 2px rgba(0, 0, 0, 0.1);
box-sizing: border-box;
-webkit-transition: all 150ms ease 0s;
transition: all 150ms ease 0s;
}
.tabs label:hover {
cursor: pointer;
}
.tabs label:after {
content: "";
background: #fefefe;
position: absolute;
bottom: -2px;
left: 0;
width: 100%;
height: 2px;
display: block;
}
.tabs input:hover + label {
background: #e08f24;
}
.tabs label:first-of-type {
z-index: 4;
}
.tab-label-2 {
z-index: 4;
}
.tab-label-3 {
z-index: 3;
}
.tab-label-4 {
z-index: 2;
}
.tabs input:checked + label {
background: #fefefe;
color: #1a1a1a;
z-index: 6;
border-top: 1px solid #4f96f6;
}
.clear-shadow {
clear: both;
}
.content {
height: auto;
width: 100%;
float: left;
position: relative;
z-index: 5;
background: #fefefe;
top: -10px;
box-sizing: border-box;
}
.content .content-title {
font-size: 1.6rm;
}
.content div {
position: relative;
float: left;
width: 0;
height: 0;
box-sizing: border-box;
top: 0;
left: 0;
z-index: 1;
opacity: 0;
background: #fefefe;
}
.content div h2 {
margin-top: 0;
}
.tabs .tab-selector-1:checked ~ .content .content-1,
.tabs .tab-selector-2:checked ~ .content .content-2,
.tabs .tab-selector-3:checked ~ .content .content-3,
.tabs .tab-selector-4:checked ~ .content .content-4 {
z-index: 100;
-ms-filter: "progid:DXImageTransform.Microsoft.Alpha(Opacity=100)";
filter: alpha(opacity=100);
opacity: 1;
width: 100%;
height: auto;
width: 100%;
height: auto;
padding: 5%;
}
.content div p {
font-size: 1.0em;
text-align: left;
margin: 0;
color: #777;
}
@media screen and (min-width: 768px) {
.tabs input:checked + label {
top: -5px;
}
}
@media screen and (max-width: 767px) {
.tabs {
height: auto;
background: #fefefe;
padding-bottom: 200px;
width: 95%;
}
.tabs label {
text-align: left;
}
.tabs input:checked + label {
padding-left: 30px;
}
.tabs label, .tabs input {
width: 100%;
position: absolute;
}
.tabs label.tab-label-1, .tabs label#tab-1, .tabs input.tab-label-1, .tabs input#tab-1 {
width: 88%;
top: 150px;
left: 0;
height: 50px;
z-index: 4 !important;
}
.tabs label.tab-label-2, .tabs label#tab-2, .tabs input.tab-label-2, .tabs input#tab-2 {
width: 92%;
top: 100px;
left: 0;
height: 100px;
z-index: 3 !important;
}
.tabs label.tab-label-3, .tabs label#tab-3, .tabs input.tab-label-3, .tabs input#tab-3 {
width: 96%;
top: 50px;
left: 0;
height: 150px;
z-index: 2 !important;
}
.tabs label.tab-label-4, .tabs label#tab-4, .tabs input.tab-label-4, .tabs input#tab-4 {
width: 100%;
top: 0;
left: 0;
height: 200px;
z-index: 1 !important;
}
.tabs .content {
top: 200px;
}
}