Web制作 JavaScript

【JavaScript】iPadを判定するuserAgent(ユーザーエージェント)の書き方【iOS13以降対応】

2021年7月5日

※ 当サイトではアフィリエイト広告を利用しています

iPadのみ適用したい処理があるんだけどどうしたらいい?

画面幅によって処理を変えるのはレスポンシブ対応が出来れば簡単ですが、同じ画面幅でもiPadでは処理を変えたいという事があるかも知れません。

今回はその方法をご紹介します。

じゅんぺいブログは、Web制作コーディングWordPress制作)の技術記事を中心に、約500記事公開しています。ぜひ他の記事も参考にしてみてください!
完全無料のプログラミングスクール『ZeroPlus Gate』
30日間でWeb制作を学べる無料のプログラミングスクールがこちら
いきなり数十万するプログラミングスクールは厳しい・・・という人のお試しに最適です。
現在は無料ですがいつ有料になるか分からないので、気になる方はお早めに👇
(有料になっていたらすいません🙇‍♂️)

\ 完全無料 /

ZeroPlus Gate公式サイト

毎日先着制!

iPadを判定するuserAgent(ユーザーエージェント)の書き方【iOS13以降対応】

まずはこちらも見て下さい。

See the Pen
by junpei (@junpei-sugiyama)
on CodePen.

パソコンやスマホで見ている方は『これはiPad以外です』と表示されていると思います。

そしてiPadで見ている人はこれはiPadです』と赤字で表示されていると思います。

 

コード解説

それではコードを見てみます。

まずはHTMLとCSSです。

<div class="container">
  <p class="ipad">これはiPadです</p>
  <p class="no-ipad">これはiPad以外です</p>
</div>
.container {
  margin-top: 50px;
}
p {
  font-size: 30px;
  font-weight: 700;
  text-align: center;
}
.ipad {
  display: none;
}

ここで見るべきところはCSSの最後です。

これはiPadで表示されるテキストを通常非表示としています。

そして重要なのはjsになります。

// iPad判別
var ua = window.navigator.userAgent.toLowerCase();
if (
  ua.indexOf("ipad") > -1 ||
  (ua.indexOf("macintosh") > -1 && "ontouchend" in document)
) {
  // iPadでの処理
  $(".ipad").css("display", "block");
  $(".ipad").css("color", "red");
  $(".no-ipad").css("display", "none");
}

最後の3行でiPadでの処理を書いています。

  • 1行目:class名『iPad』を表示させる
  • 2行目:class名『iPad』のフォントを赤色にする
  • 3行目:class名『no-ipad』を非表示にする

となります。

今回はCSSのプロパティを変更しただけですが、classの付け替えなど色んな処理が出来ます(ここではiPadでの処理の部分はjQueryを使用しているので、jQuery本体の読み込みを忘れないようにして下さい)

jQueryを使ったことがない人はこちらの記事を参照下さい。

あわせて読みたい
【初心者向け】jQueryとは?CDNを使った本体の読み込み方についても分かりやすく解説
【初心者向け】jQueryとは?CDNを使った本体の読み込み方も分かりやすく解説

続きを見る

まとめ

今回はJavaScriptでiPadを判定するuserAgentの書き方を解説しました。

あまり使う機会はないかも知れませんが、実際に実務で使った事があるので覚えておいて損はないかと思います。

以上になります。

この記事が役に立ったと思ったら、シェアボタンからX(旧Twitter)などにシェアすると、いいねされてフォロワーが増えたりすることがあるよ!

 

  • この記事を書いた人

じゅんぺい

37歳からWeb制作とブログ開始。Web制作歴5年目でコーディングとWordPressオリジナルテーマ制作が中心。これまで120件以上を納品。当ブログ月間最高15万PVで、370記事以上はWeb制作の技術記事。コンテンツ販売→累計売上1200万円&1500部超え。X(旧Twitter)フォロワー7200人以上。2024年3月からブログの経験を活かしてライターとしても活動を開始。

-Web制作, JavaScript