LoginSignup
213
211

More than 1 year has passed since last update.

サイトやアプリのUIデザインをする時に知っておくと良いアクセシビリティのこと

Last updated at Posted at 2022-12-17

はじめに

デザイナー以外の方でも、サイトやアプリを作るためにUIを作成することはよくあると思います。
そんな時に最低限知っておくと良さそうな、アクセシビリティに関するTipsをまとめてみました。

この記事で紹介する以外にも色々とあるとは思うので、是非コメントなどで「これも追加した方がいいんじゃないか」など提案いただけると助かります!

この記事ではFigmaなどのデザインツールでUIをデザインする段階を想定しています。
そのため、「ボタンはdivでなくbuttonで実装する」「アイコンフォントにaria-labelをつける」「音声を勝手に再生しない」といった実装段階のポイントは扱いません。

読みやすい文字のサイズや色、フォントを使う

文字サイズ

Webサイトやアプリで使われている本文のフォントサイズは14~18pxが多いです。

また、W3Cでは英文の場合18ポイント以上もしくは、14ポイント以上の太字、日本語の場合それと同等のサイズが推奨されています。

16pxを基準に、対象ユーザーやコンテンツに合わせてサイズを大きくすることを検討するのが良いと思います。

また、12pxよりも小さい文字サイズは読みづらいため使用を避けましょう。

フォント

細身のフォントや字の形を変形させたようなフォント、装飾のあるフォントなどは読みづらくなるので、読ませる文章には癖のないフォントを使いましょう。

ヒラギノ角ゴシックや游明朝体のような癖のないフォントは長文でも読みやすく、手書きのような崩したフォントや、筆で書いたような装飾のあるフォントは長文では読みづらい

フォントの選び方については、こちらのサイトの解説がわかりやすくおすすめです。

行間や、1行当たりの文字数を調整して、文章を読みやすくする

行間

W3Cの達成基準によると、line-heightを1.5em以上、段落間の空白を2em以上、にする必要があります。

line-heightは狭すぎても広すぎても文字が読みづらくなってしまうため、1.5em ~ 2emを目安に調整するのがおすすめです。

180%だと、一行一行が分かりやすく、視線移動が混乱しにくい。120%だと、一行一行が近いので視線移動が混乱しやすく、読みにくくなる。

1行当たりの文字数

また、日本語で読みやすい1行当たりの文字数は40文字程度と言われています。
1行当たりの文字数が長くなると、文章が読みづらくなります。

ちなみに私が読みやすいと思う文章の設定はこんな感じです。

font-size: 18px;
font-family: serif;
width: 640px; /* 1行当たり35文字程度 */
line-height: 1.9;

人によって読みやすい文章は異なるので、自分の読みやすいスタイルを知っておくと長い文章を読むときにサッと拡張機能などでカスタマイズできるのでおすすめです。

アイコンを使う時のポイント

できるだけアイコンだけでなくラベルをつける

テキストではなくアイコンを使うと、スペースを削減できます。

また、アイコンのような視覚要素は直感的に機能を理解できます。

てきすとだけで「ホーム」と書いてあるボタンと、テキストの横に家のアイコンがあるボタン

一方で、テキストラベルなしのアイコンにはいくつか課題があります。

例えばマイクのアイコンとマイクに取り消し線があるアイコンがあった時、「今の状態を表している」のか「起こるアクションの内容を表している」のか判断がつきません。

マイクのアイコンとマイクに取り消し線の入ったアイコン

しかし、「ミュートを解除する」「ミュートにする」というラベルをそれぞれ付け加えれば何が起こるかすぐに理解できます。

マイクのアイコンにミュートを解除するのラベルがついているボタンとマイクに取り消し線の入ったアイコンにミュートにするのラベルがついているボタン

また、アイコンの意味を理解できたとしても「これはどういう意味だろう」「きっとこうだろう」と考える負荷がかかります。

他にも、形状が似ているアイコンを見間違えやすかったりアイコンの意味を推測するのが苦手な人もいます。
ラベルを付加することでこうした課題を解決できます。

一般的なアイコンを使う

アイコンを使うときは一般的に使用されているものを使いましょう。

例えば「ホーム」なら家の形、検索なら虫眼鏡、送信なら紙飛行機のように様々なサービスで使われているアイコンがあります。
こうしたアイコンを使うことで、アイコンの意味を推測する負荷や記憶する負荷を減らすことができます。

リンクやボタン、フォームのポイント

同じ挙動をするボタンや同じ遷移先のリンクに一貫したテキストやアイコンを使う

UIでボタンやリンクを設置する場合は、一貫性のあるテキストやアイコンを使いましょう。

例えば「お気に入りリストに保存する」というボタンのアイコンが場所によって❤️だったり⭐️だったり、テキストが「お気に入り」だったり「ストック」だったりすると、ユーザーはそれらが同じ挙動をするのかわからず混乱してしまいます。

逆に使用されているアイコンやテキストに一貫性があると、ユーザーはボタンを押すと何が起こるかやリンクがどこに遷移するかを理解しやすくなります。

W3Cの「一貫した識別性:達成基準 3.2.4 を理解する」で詳しく一貫性について解説されているので、是非こちらもご覧ください。

ボタンのタップできるエリアを十分に確保する

ボタンをタップしようとして上手くタップできなくて困った経験がありませんか?
小さすぎるボタンのタップエリアは特に細かい操作が苦手なユーザーや細かい部分が見えづらいユーザーにとって、操作しづらかったり、誤って他の場所をタップしてしまい誤操作に繋がったりします。

こうしたタップエリアについては様々なガイドラインで基準が設けられているので、十分なタップエリアを確保するようにしましょう。

フォームのラベルをプレースホルダーだけにしない

入力フォームのラベルをプレースホルダーにしてしまうと、フォームにフォーカスして入力を開始したときにラベルが見えなくなってしまいます。

ユーザーが入力中ラベルを覚えている必要があったり、最後に見返すときにラベルと入力項目を照らして確認することができなくなります。
また、プレースホルダーに使用される色は入力済みと区別できるよう薄いグレーがよく使われますが、背景とのコントラストが低いためテキストが読みづらくなります。

そのため、 入力フォームを用意するときのラベルはプレースホルダーではなく入力フォームの外側に用意しましょう。

フォームで制限がある場合は、あらかじめ伝える

もしフォームで入力できる文字数や使える値の書式に制限がある場合は、できるだけはじめに伝えましょう。
せっかくユーザーが項目を入力してくれた後にエラーを表示すると、その分手間が増えたりネガティブな感情に繋がってしまいます。

入力フォームに入力をしてからエラー文を出すのでなく、あらかじめラベルの近くに条件を書いておく。

エラー内容と修正方法が分かるようなエラーメッセージを表示する

エラーメッセージを表示するときは、エラーの内容とどうすればそれが修正できるかが分かるようなメッセージを表示しましょう。

単純に「エラーが発生しました」と伝えるだけではユーザーはそのあとどうすれば良いか分からず、操作を中断して調べる必要があったり、サービスの使用自体をやめてしまうかもしれません。

また、エラー文で使うテキストは専門的な言葉やシステム目線の言葉遣いでなく、一般的に使われている言葉でユーザーがどうすればいいのかを書きましょう。

重大な操作は、確認や修正、取り消しができるようにする

データの削除など、取り返しのつかない重大なアクションをする時には、内容の確認や修正ができるようにしたり、取り消しを可能にしましょう。

データを削除する際に、すぐに削除せず確認のモーダルを出す。削除するボタンは重要で取り返しがつかないことがわかるよう赤いボタンにしている。近くにキャンセルボタンを置いて、簡単に取り消せるようにする。

小ネタ的な内容ですが、取り返しのつかない操作について「キャンセルのキャンセル」という有名な問題があります。

何かをキャンセルするアクションをさせるときに、「キャンセルしますか?」という問いかけと「キャンセル」というボタンがあったとします。

この時に「キャンセル」」ボタンが「はい、キャンセルします」なのか「いいえ、キャンセルするのをキャンセルします」なのか分からないという問題です。

特に取り返しのつかない操作にこうした曖昧さがあると、重大な誤操作に繋がってしまうので、何かアクションをさせるときは表現が明快かチェックするようにしましょう!

おわりに

ここまで読んでいただきありがとうございます!

記事を書くにあたって参考にしたサイトのリンクはこちらです。
この記事では紹介していない内容もたくさんありますので是非興味があれば読んでみてください。

213
211
1

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
213
211