10
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 1 year has passed since last update.

Ateam LifeDesignAdvent Calendar 2023

Day 7

viewport sizeにあわせて変化しつつアクセシブルかもしれないfont-size指定

Last updated at Posted at 2023-12-06

この記事の概要

font-size の指定に vwvh などの単位を使用する場合、アクセシビリティ的な問題が起きます。

ユーザーがブラウザの設定としてフォントサイズを変えていても、それが反映されなくなることです。

とは言え vw などで文字のサイズを指定するのが便利な場面もありますから、上手くやれないかと思い考えてみました。

タイトルに「かもしれない」と入れている通り、確証はありません。
ハック的な感じがしますし、コードの理解しやすさも下がっていると思います。
これをきっかけにもっと良いやり方が生まれたら嬉しいです。

内容

仮に 2vw 相当のサイズを指定する場合、次のようになります。

@property --1vw {
  syntax: "<length>";
  inherits: true;
  initial-value: 0px;
}

:root {
  --1vw: 1vw;
  --vw-to-px: calc(tan(atan2(var(--1vw), 1px)));
}

p {
  font-size: calc(var(--vw-to-px) * 1rem / 16 * 2);
}

@property --1vw の部分は、現在 atan2 にバグがあるらしく、それを回避するための記述です。

上記の対応が不要であれば tan(atan2(var(--1vw), 1px)) の部分は本来 tan(atan2(1vw, 1px)) と書けます。
これは 1vw をピクセル換算した際、何ピクセルあるのか を表しています。

このあたりの詳しい内容はこちらの記事をご覧ください。
若干記載が違いますが、ほとんど同じことをやっています。

次に font-size ですが --vw-to-px つまりピクセル換算した vw1rem をかけて 16 で割ることで単位を rem へ変換しています。

最後の * 22vw を表したいので 2 です。
もし 3vw を表したければ * 34vw を表したければ * 4 です。

挙動

今回のやり方で作ったものはこのように動きます。
viewport 幅にあわせてフォントサイズが変わりつつ、設定のフォントサイズも反映されます。

逆に、通常の vw の指定だとこのようになります。
ブラウザの設定が反映されていません。

最後に

この記事の途中で引用したものを読んでいる最中にふと浮かび作ってみましたが、実用的かというと……であります。

記事の冒頭で記載していたように、この記事を通じてより良いやり方が生まれたらとても嬉しいです。

10
4
0

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
10
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?