レスポンシブ対応で右カラムのコンテンツを上に表示させる方法
2024/01/16
レスポンシブ対応サイトの簡易なコーディングをする経験があった。何も考えずに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のみで作成する方法
コンテンツ内をスクロールしても追尾してくる要素を作成したかった。以前にMeeka ...
-
-
jQueryの日付&時間のピッカー(bootstrap-datetimepicker)について
日付のピッカーはよく見るけど、時間のピッカーはあまり見ないので、普通のセレクトメ ...
-
-
videoタグで表示させた動画をjQuery&CSSでフローティングビデオ対応させる方法
Web上の動画をFloatingVideo対応したいという要望を受けた。ページ上 ...
-
-
CSSのdisplayについて
よく使うdisplayだけれども、noneとblock以外で 初めて使うことがあ ...
-
-
CSSで1つの要素に複数classを設定して画像を入れ替える方法
メニューリンクで通常時の画像、マウスオーバー時の画像、アクティブ時の画像をそれぞ ...