Android用にメディアクエリ(media query)で表示振り分け

PCサイトでoverflow:scrollによる擬似インラインフレームを使ったページがあったんですが、スマホでうまく表示できない。
調べてみると、そもそもスマホではインラインフレームとoverflow:hiddenを同じものとして扱っていて、さらにiPhoneとAndroidでその扱いにも差があることがわかりました。

インラインフレーム、overflow:hiddenの扱い

iPhoneの場合

表示はする
スクロールは2本指でスクロール

Androidの場合

表示はする
スクロールは出来ない

iPhoneの「2本指スクロール」というのもかなりマニアックな操作方法というか、未だに知らない人も多いかと思われます。
Androidはそもそもスクロールできないとのことなので、使わないほうが無難ですね。

しかしPCサイトではoverflowスクロールをどうしてもさせたい、という要求があることもあります。

そんなときは、CSS3のメディアクエリで動作を分けて対応しましょう。

メディアクエリでスマホ用に表示変更

というわけで用意したのがこんなCSS

#scroll-box{
    height:500px;
    overflow:auto;
}
@media screen and (max-device-width: 320px) {
    #scroll-box {
        height: auto;
        overflow: visible;
    }
}

最初の指定をPCで読み込み、次の指定は横幅が320px以下の環境で見た時だけ適用されます。

広告

これで安心、と思いきや「Androidに適用されていない」という現象が。
確認のために、JavaScriptで画面幅をみてみると…

<script>
document.write(screen.width);
</script>

手持ちのAndroid機は「902px」でした。道理で作動しないわけです。

というわけで対応幅をぐっと広げて

@media screen and (max-device-width: 1025px) {
    #scroll-box {
        height: auto;
        overflow: visible;
    }
}

にしました。
1025pxは、iPadの横表示時のサイズです。
この幅だと小さめのノートPCの時にも引っかかりますのでご注意を。
今回の場合は表示よりも動作優先なので、これで行きます。

About: dacelo


Leave a Reply

Your email address will not be published. Required fields are marked *