HTMLで改行でずれるレイアウトの原因と対処法を現役エンジニアが解説【初心者向け】
初心者向けにHTMLで改行でずれるレイアウトの原因と対処法について解説しています。HTMLのレイアウトにおける基本原則、
タグを使うべき場面、そうでない場面について説明します。改行の適切な使い方を覚えましょう。
テックアカデミーマガジンは受講者数No.1のプログラミングスクール「テックアカデミー」が運営。初心者向けにプロが解説した記事を公開中。現役エンジニアの方はこちらをご覧ください。 ※ アンケートモニター提供元:GMOリサーチ株式会社 調査期間:2021年8月12日~8月16日 調査対象:2020年8月以降にプログラミングスクールを受講した18~80歳の男女1,000名 調査手法:インターネット調査
HTMLで改行でずれるレイアウトの原因と対処法について、TechAcademyのメンター(現役エンジニア)が実際のコードを使用して初心者向けに解説します。
そもそも、HTMLの記述方法がわからない場合は、HTMLの書き方について解説した記事を読むとさらに理解が深まります。
なお本記事は、TechAcademyのオンラインブートキャンプ、Webデザイン講座のHTMLカリキュラムをもとに執筆しています。
今回は、HTMLに関する内容だね!
どういう内容でしょうか?
改行でずれるレイアウトの原因と対処法について詳しく説明していくね!
お願いします!
目次
HTMLの改行の意味
HTMLの改行である<br>属性は、テキスト文章の中で改行を行う場合に使用します。改行は文章の区切りとして用います。
HTMLの改行の注意点
HTMLはタグを使った構造であるため、以下のようにテキスト上で改行を行ってもWebサイトでは無視されて連続して表示されます。
あいうえお かきくけこ
実行結果は以下のようになります。
あいうえおかきくけこ
<br>要素を使用することで改行を行うことが出来ます。
あいうえお<br> かきくけこ
実行結果は以下のようになります。
あいうえお かきくけこ
HTMLの改行とレイアウトの関係
HTMLの改行をレイアウトの調整で使用すべきではありません。HTMLは要素にそれぞれの意味がある言語です。
<br>要素は改行という意味であり、レイアウトを調整する意味はありません。もっとも影響があるのはアクセシビリティです。<br>要素をレイアウトで使用すると、読み上げソフトで誤って改行として認識してしまいます。レイアウトの調整は<p>要素や<div>要素を使い、CSSでmarginを設定して行うようにしましょう。
<br>要素について、詳しくは以下の記事も参考にしてください。
関連記事:HTMLでbrタグの使い方と正しい改行方法を現役エンジニアが解説【初心者向け】
HTMLを改行するとずれるレイアウトの原因と対処法
前述のとおり、改行は本来の改行としての意味で使用します。なおHTML中に全角空白が存在するとその部分の改行がずれて表示されますので注意しましょう。
それでは<br>要素とレイアウトを使ったサンプルを例で確認してみましょう。文章は青空文庫から「雨ニモマケズ」を引用しています。
<!DOCTYPE html> <html lang="ja"> <head> <meta charset="UTF-8" /> <meta name="viewport" content="width=device-width, initial-scale=1.0" /> <meta http-equiv="Cache-Control" content="no-cache" /> <title>Sample</title> <style> p { margin-bottom: 0.5rem; } </style> </head> <body> <p> 雨ニモマケズ<br /> 風ニモマケズ<br /> 雪ニモ夏ノ暑サニモマケヌ<br /> 丈夫ナカラダヲモチ<br /> 慾ハナク<br /> 決シテ瞋ラズ<br /> イツモシヅカニワラッテヰル<br /> </p> <p> 一日ニ玄米四合ト<br /> 味噌ト少シノ野菜ヲタベ<br /> アラユルコトヲ<br /> ジブンヲカンジョウニ入レズニ<br /> ヨクミキキシワカリ<br /> </p> </body> </html>
実行結果は以下のようになります。文としての改行が<br>要素で行われ、レイアウトの調整は<p>要素に設定したCSSで行われていることが確認できます。
まとめ
今回の記事ではHTMLで改行でずれるレイアウトの原因と対処法について学習しました。
監修してくれたメンター
太田和樹(おおたかずき)
ITベンチャー企業のPM兼エンジニア 普段は主に、Web系アプリケーション開発のプロジェクトマネージャーとプログラミング講師を行っている。守備範囲はフロントエンド、モバイル、サーバサイド、データサイエンティストと幅広い。その幅広い知見を生かして、複数の領域を組み合わせた新しい提案をするのが得意。 開発実績:画像認識技術を活用した駐車場混雑状況把握、音声認識を活用したヘルプデスク支援システム、ロボットアプリの開発、大規模基幹系システムの開発・導入マネジメント。著書「知識ゼロからの機械学習入門(技術評論社)」。 地方在住。仕事のほとんどをリモートオフィスで行う。通勤で消耗する代わりに趣味のDIYや家庭菜園、家族との時間を楽しんでいる。 |
内容分かりやすくて良かったです!
ゆかりちゃんも分からないことがあったら質問してね!
分かりました。ありがとうございます!
TechAcademyでは初心者でも、オリジナルWebサイトを公開できる、オンラインブートキャンプを開催しています。
また、現役エンジニアから学べる無料体験も実施しているので、ぜひ参加してみてください。