##Bootstrap4にて、Navbarを均等に表示したい!
結論から言うと、ナビゲーションメニューの要素を囲っている親タグに、w-100 nav-justified
というクラスを書き加えてあげるだけでOKです!
今回の例で言うと、
<a class="navbar-nav w-100 nav-justified">
という記載をしてあげればオッケーです。
###通常のNavbarの書きかた
まずは通常のNavbarの記載方法です。このようなNavbarを作ることができます。
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>Document</title>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css">
<meta name="viewport" content="width=device-width, initial-scale=1.0">
</head>
<body>
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup" aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
<div class="navbar-nav">
<a class="nav-item nav-link active" href="#">Home <span class="sr-only">(current)</span></a>
<a class="nav-item nav-link" href="#">Features</a>
<a class="nav-item nav-link" href="#">Pricing</a>
<a class="nav-item nav-link disabled" href="#">Disabled</a>
</div>
</div>
</nav>
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.0/umd/popper.min.js" integrity="sha384-cs/chFZiN24E4KMATLdqdvsezGxaGsi4hLGOzlXwp5UZB1LY//20VyM2taTB4QvJ" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.0/js/bootstrap.min.js" integrity="sha384-uefMccjFJAIv6A+rW+L4AHf99KvxDjWSu1z9VI8SKNVmz4sk7buKt/6v9KI65qnm" crossorigin="anonymous"></script>
</body>
</html>
###全幅均等表示するNavbarの書きかた
先程も書いたとおり、class="navbar-nav"
の記載がある場所に、w-100 nav-justified
というクラスを書き加えてあげるだけです!
すると・・・以下のようになります!!
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="UTF-8">
<title>Document</title>
<link rel="stylesheet" href="https://stackpath.bootstrapcdn.com/bootstrap/4.1.1/css/bootstrap.min.css">
</head>
<body>
<nav class="navbar navbar-expand-lg navbar-light bg-light">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#navbarNavAltMarkup" aria-controls="navbarNavAltMarkup" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarNavAltMarkup">
<!--↓今回書き加えたのはここだけ!↓-->
<div class="navbar-nav w-100 nav-justified">
<a class="nav-item nav-link active" href="#">Home <span class="sr-only">(current)</span></a>
<a class="nav-item nav-link" href="#">Features</a>
<a class="nav-item nav-link" href="#">Pricing</a>
<a class="nav-item nav-link disabled" href="#">Disabled</a>
</div>
</div>
</nav>
<script src="https://code.jquery.com/jquery-3.3.1.slim.min.js" integrity="sha384-q8i/X+965DzO0rT7abK41JStQIAqVgRVzpbzo5smXKp4YfRvH+8abtTE1Pi6jizo" crossorigin="anonymous"></script>
<script src="https://cdnjs.cloudflare.com/ajax/libs/popper.js/1.14.0/umd/popper.min.js" integrity="sha384-cs/chFZiN24E4KMATLdqdvsezGxaGsi4hLGOzlXwp5UZB1LY//20VyM2taTB4QvJ" crossorigin="anonymous"></script>
<script src="https://stackpath.bootstrapcdn.com/bootstrap/4.1.0/js/bootstrap.min.js" integrity="sha384-uefMccjFJAIv6A+rW+L4AHf99KvxDjWSu1z9VI8SKNVmz4sk7buKt/6v9KI65qnm" crossorigin="anonymous"></script>
</body>
</html>
場合によっては、ナブバーのメニューがaタグじゃなくてul,liタグなこともあります。そんなときも、ナビゲーションメニューの要素を囲っているタグ(この場合liタグ)の親タグ(ulタグ)にクラスをくけ加えてあげればOKです!
<nav class="navbar navbar-expand-lg">
<!-- ロゴ -->
<a class="navbar-brand">hogehoge</a>
<!-- スマホ用ナブバー展開ボタン -->
<button class="navbar-toggler" type="button" data-toggle="collapse" data-target="#tampopoNavbar" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<!-- navbarの要素 -->
<div class="collapse navbar-collapse" id="tampopoNavbar">
<ul class="navbar-nav nav-fill w-100 nav-justified">
<!-- ドロップダウンしないナブバーメニュー -->
<li class="nav-item"><a href="" class="nav-link ">メニュー1</a></li>
<li class="nav-item"><a href="" class="nav-link">メニュー2</a></li>
<li class="nav-item"><a href="" class="nav-link">メニュー3</a></li>
<li class="nav-item"><a href="" class="nav-link">メニュー3</a></li>
<li class="nav-item"><a href="" class="nav-link">メニュー3</a></li>
<!-- ドロップダウンする -->
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" id="navbarDropdownMenuLink" data-toggle="dropdown" aria-haspopup="true" aria-expanded="false">Dropdown link</a>
<div class="dropdown-menu" aria-labelledby="navbarDropdownMenuLink">
<a class="dropdown-item" href="#">Action</a>
<a class="dropdown-item" href="#">Another action</a>
<a class="dropdown-item" href="#">Something else here</a>
</div>
</li>
</ul>
</div>
</nav>
ちなみに、w-100
とは、
width: 100%;
と同義です。また、navbar-light
というクラスは、navbarのリンク要素を青地にするのを防ぐ効果があります。
現場からは以上です。
2018/05/11追記:
上のnavbar_ul_li.html
のnavbarのul要素内クラスがnav
と誤って記述されていました。正しくはnavbar-nav
です。
ナブバーのリンク部分が青くなっていて、navbar-light
を使用しても色が変わらないので変だな・・・と思って調べたらこのような誤りだったっぽいです。すみませんでした。
###参考サイト
今回は、こちらを参考にしました。