勉強したことのメモ

Webエンジニア / プログラマが勉強したことのメモ。

レスポンシブ対応で右カラムのコンテンツを上に表示させる方法

   2024/01/16  CSS

レスポンシブ対応サイトの簡易なコーディングをする経験があった。何も考えずにHTMLを上から書いていくと最初に左カラム部分の作成し、次に右カラム部分を書くことになる。ただ、スマホで閲覧した際に右カラム部分を上部に、左カラム部分を下部に表示させたかった。以下に方法をメモ。

 

HTML部分

<div class="container">

    <div class="right">
        right
    </div>

    <div class="left">
        left
    </div>

</div>

 

CSS

.container{
    display: flex;
    max-width: 100%;
}
.left{
    width: 50%;
    height: 500px;
    background-color: #555;
    order: 1;
}
.right{
    width: 50%;
    height: 500px;
    background-color: #f00;
    order: 2;
}

@media screen and (max-width: 700px) {
    .container{
        display: inline-block;
        width: 100%;
        max-width: 100%;
    }

    .left{
        width: 100%;
        max-width: 100%;
    }

    .right{
        width: 100%;
        max-width: 100%;
    }
}

HTMLのソースコードを見る限りだと.rightが左にきそうだが、CSSのorderプロパティを指定することで順序を決められる。ディスプレイ横幅が700px以下になるとそれが解除され、HTMLのソースコード通り.rightが上に来る。

 - CSS

  関連記事

CodeIgniter4&Bootstrap&jQueryで簡易版お問い合わせページの作成

CodeIgniter4.4.4&Bootstrap&jQuer ...

CSSのdisplayについて

よく使うdisplayだけれども、noneとblock以外で 初めて使うことがあ ...

CSSで1つの要素に複数classを設定して画像を入れ替える方法

メニューリンクで通常時の画像、マウスオーバー時の画像、アクティブ時の画像をそれぞ ...

videoタグで表示させた動画をjQuery&CSSでフローティングビデオ対応させる方法

Web上の動画をFloatingVideo対応したいという要望を受けた。ページ上 ...

YouTubeの埋め込み動画をjQuery&CSSでフローティングビデオ対応させる方法

以前にvideoタグで表示させた動画をjQuery&CSSでフローティン ...