質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.48%
Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

397閲覧

cssレイアウトについて

tetsuya7724

総合スコア67

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

1クリップ

投稿2020/05/14 08:05

前提・実現したいこと

cssについてです。
ヘッダー部分のリンク(logout,dashboard等)の部分を右端に寄せたいです。
PCの画面でも画面を小さくしても、文字の配列を変えずに右端に寄せられるようにしたいのですが、どこを対象にcssコードを入れたらいいでしょうか。

リンクはすべて横一列に配置したいです。

該当のソースコード

html

1 <header> 2 3 <div class="container header-title"> 4 <div class="navbar navbar-expand-sm"> 5 <a class="eden" href="/">薬物サイト</a> 6 <div class="collapse navbar-collaps" id="navbarNav"> 7   <% if user_signed_in? %> <!-- ユーザーがログインしているか調べる --> 8 <ul class="navbar-nav ml-auto"> 9 <!-- ユーザーがログインしていた時の処理 --> 10 <li class="nav-item"> 11 <%= link_to "ABOUT", "/posts/about" %> 12 </li> 13 <li class="nav-item"> 14 <%= link_to "DASHBOARD", "/posts/dashboard" %> 15 </li> 16 <li class="nav-item"> 17 <%= link_to "LESSONS", "/posts/lessons" %> 18 </li> 19 <li class="nav-item"> 20 <%= link_to "PROFILE", "/posts/profile" %> 21 </li> 22 <li class="nav-item"> 23 <%= link_to "SETTING", edit_user_registration_path %> <!-- ログアウトをする --> 24 </li> 25 <li class="nav-item"> 26 <%= link_to "LOGOUT", destroy_user_session_path, method: :delete %> <!-- ログアウトをする --> 27 </li> 28 <% else %> 29 <!-- ユーザーがログインしていなかった時の処理 --> 30 <li class="nav-item"> 31 <%= link_to "LOGIN", new_user_session_path, class: 'post' %> <!-- ログイン画面に移行する --> 32 </li> 33 <li class="nav-item"> 34 <%= link_to "SIGNUP", new_user_registration_path, class: 'post' %> <!-- 新規登録画面に移行する --> 35 </li> 36 <li class="nav-item"> 37 <%= link_to "ABOUT", "/posts/about" %> 38 </li> 39 40 </ul> 41<% end %> 42</div> 43</div> 44</div> 45 </header>

css

1 2.navbar{ 3 display: flex; 4} 5 6.collapse { 7 margin-left: 50%; 8} 9 10.navbar li{ 11 float: left; 12 padding-right: 10px; 13} 14 15.eden{ 16 color: white; 17 text-decoration: none; 18 font-size: 30px; 19} 20 21.navbar-nav a{ 22 color: white; 23 text-decoration: none; 24} 25 26body { 27 background-color: #01805A; 28} 29 30.nav-item{ 31 list-style: none; 32 33} 34 35.nav-item a{ 36 color: white; 37 text-decoration: none; 38} 39 40.log{ 41 color: white; 42 text-decoration: none; 43} 44 45.copyright{ 46 text-align: center; 47} 48 49

試したこと

コードに載せている通り

css

1.collapse { 2 margin-left: 50%; 3}

とするとPC画面の時は思い通りの配列と配置になるのですが、画面を小さくするとログアウト等の配列がおかしくなります。

PC画面
イメージ説明

小さい画面
イメージ説明

補足情報(FW/ツールのバージョンなど)

ここにより詳細な情報を記載してください。

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

Lhankor_Mhy

2020/05/14 08:14

bootstrapを使っているのではありませんか?
tetsuya7724

2020/05/14 08:18

bootstrapを使っています。ただ画面を小さくしても配列は変わらないようにしたかったので入れています。 スマホでも表示できるようにしたいので、bootstrapは外せないです。
Lhankor_Mhy

2020/05/14 08:23

bootstrapにはCSSが含まれていますから、その影響を受けてスタイルが変わります。 質問本文でその旨の補足をした方が、回答がしやすいかと思います。
tetsuya7724

2020/05/14 08:29

なるほど、わかりました。
guest

回答1

0

ベストアンサー

「質問への追記・修正の依頼」を拝見しまして、Bootstrapを用いているとのこと。
Bootstrapでは、
.d-none .d-sm-none .d-md-none .d-lg-none .d-xl-none

のように、画面サイズによって、要素をdisplay:none;するクラスがあります。

スマホ画面でもヘッダー部分を全て消したくないとなると、

① navをハンバーガーメニューにして、そこにナビアイテムを入れる

②文字をめちゃくちゃ小さくして何とか横一列にする

とか考えられます。

それ以外、例えば、「画面が小さくなってもLOGOUT、DASHBOARDだけは消したくない」

という場合には、LOGOUT、DASHBOARD以外のナビアイテムに.d-sm-noneや.d-md-none

をつけるといいんではないでしょうか。

投稿2020/06/18 13:38

ff7575

総合スコア123

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.48%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問