今回は、Vue.jsとBootstrapVueを使ってヘッダーとフッターを作成していこうと思います!
BootstrapのNavbarやNavsを使って実装していきますので、使い方がいまいちわからない方や気になっていた方は、ぜひ参考にしてみてください!
学習に使った本はこちら!
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
Amazon Kindle Unlimited でもVue.jsの本はいっぱいあるんじゃ!!
まだVue.jsの環境構築をしていない方は、こちらの記事を参考にして構築してみてください!
data:image/s3,"s3://crabby-images/15a75/15a750a8e15b600597885c1ffaf15a5985d44cbc" alt=""
data:image/s3,"s3://crabby-images/15a75/15a750a8e15b600597885c1ffaf15a5985d44cbc" alt=""
Vue.jsにBootstrapを導入していない方は、こちらの記事を参考にして導入してみてください!
data:image/s3,"s3://crabby-images/2110b/2110b64303dbb1adc50c77c028dd964aaf2a1090" alt=""
data:image/s3,"s3://crabby-images/2110b/2110b64303dbb1adc50c77c028dd964aaf2a1090" alt=""
では、早速ヘッダーとフッターを作っていこうと思います!
data:image/s3,"s3://crabby-images/5c242/5c242dcf960d2c3dc03bdee398bdb185c1ff51d2" alt=""
data:image/s3,"s3://crabby-images/5c242/5c242dcf960d2c3dc03bdee398bdb185c1ff51d2" alt=""
data:image/s3,"s3://crabby-images/5c242/5c242dcf960d2c3dc03bdee398bdb185c1ff51d2" alt=""
わしでもおしゃれなヘッダーが作れるかのう?
Navbarを使ってヘッダーを作ろう!
では早速、実装していこうと思います!!
フォルダ構成を整理しておこう!
前回の「Vue.jsにBootstrapを導入してみよう!」を参考にしてくれた方だと、現在のフォルダ構成はこのような感じになっていると思います!
data:image/s3,"s3://crabby-images/dfe62/dfe62950b7fdc54b94dd29c81a402a30cab8a024" alt="v sample-client
) node modules
> public
v components
V He IoWoddvue
V App.vue
main js
.gitignore
b abeLconfig.js
O package-json
READMEmd"
data:image/s3,"s3://crabby-images/dfe62/dfe62950b7fdc54b94dd29c81a402a30cab8a024" alt="v sample-client
) node modules
> public
v components
V He IoWoddvue
V App.vue
main js
.gitignore
b abeLconfig.js
O package-json
READMEmd"
基本的には、実装したものを「components」に格納していくのですが、このまま全て「components」に格納してしまうと後々大変になってしまいます。
今回は、あまり大きな開発をするわけではないので、components配下に「modules」と「pages」を作成することにします!
「modules」と「pages」の目的は、それぞれこのようにします!
- pages
-
modulesを活用してページを格納します。1画面毎にファイルができてくる想定です!
- modules
-
画面を構成するパーツを格納していくフォルダ。どんどんここに入れていきます!
フォルダの作成は、「components」で右クリック>NewFolderで作成が可能です!
pagesとmodulesを作成してこのようになっていればOKです!
data:image/s3,"s3://crabby-images/a7437/a7437c90b3184f861c5fe8cae1eecc494ab1f0f9" alt="v sample-client
) node mu)dules
> assets
v Com POI" entS
> rncdules
> pages
V App .vue
JS main js
O .gitignore
Babel -config j s
O
package-lock.j„. M
O
packagejson
READMEmd"
data:image/s3,"s3://crabby-images/a7437/a7437c90b3184f861c5fe8cae1eecc494ab1f0f9" alt="v sample-client
) node mu)dules
> assets
v Com POI" entS
> rncdules
> pages
V App .vue
JS main js
O .gitignore
Babel -config j s
O
package-lock.j„. M
O
packagejson
READMEmd"
では、早速ヘッダー用のVueファイルを作成していきましょう!
ヘッダーは、App.vueにて使われるのもですのでmodulesに作成していきます!
modulesで右クリック>New Fileでファイルを作成し、名前を「Header.vue」としましょう!
このようになっていれば、大丈夫です!
data:image/s3,"s3://crabby-images/632ba/632ba93201772b19b84211ba54d05559efe07966" alt="< sanvle-cl•ent
@ README-rn•d
pa 」 50n M
、 con js
》 node modules
main-Js
V 工 2 = OWOI ; M
"'tignore
( modules
V Header.vue u"
data:image/s3,"s3://crabby-images/632ba/632ba93201772b19b84211ba54d05559efe07966" alt="< sanvle-cl•ent
@ README-rn•d
pa 」 50n M
、 con js
》 node modules
main-Js
V 工 2 = OWOI ; M
"'tignore
( modules
V Header.vue u"
ヘッダーを実装していこう!
今回のヘッダーは、BootstrapVueのnavbarを使って実装します。
data:image/s3,"s3://crabby-images/01566/015661fb46eb5259366819e4d14540c339c7f551" alt=""
data:image/s3,"s3://crabby-images/01566/015661fb46eb5259366819e4d14540c339c7f551" alt=""
Header.vueとApp.vueをそれぞれ下のように変更してみてください!
もし、BootstrapVueのサンプルで気に入ったのがあれば、Header.vueの中身を好きなように変更してもらっても大丈夫です!
App.vueは、追加した行に一応コメントを振ってます!
「margin-top: 60px; 」の記載がある方は、ヘッダーを作る上では邪魔なので、消してしまって問題ないです。
(今回は「/* margin-top: 60px; */」とコメントアウトしています!)
Header.vue
<template>
<div>
<b-navbar type="dark" variant="dark">
<b-navbar-nav>
<b-nav-item href="#">Home</b-nav-item>
<!-- Navbar dropdowns -->
<b-nav-item-dropdown text="Lang" right>
<b-dropdown-item href="#">EN</b-dropdown-item>
<b-dropdown-item href="#">ES</b-dropdown-item>
<b-dropdown-item href="#">RU</b-dropdown-item>
<b-dropdown-item href="#">FA</b-dropdown-item>
</b-nav-item-dropdown>
<b-nav-item-dropdown text="User" right>
<b-dropdown-item href="#">Account</b-dropdown-item>
<b-dropdown-item href="#">Settings</b-dropdown-item>
</b-nav-item-dropdown>
</b-navbar-nav>
</b-navbar>
</div>
</template>
App.vue
<template>
<div id="app">
<!-- <Header />でHeader.vueを表示 -->
<Header />
<img alt="Vue logo" src="./assets/logo.png" />
<HelloWorld msg="Welcome to Your Vue.js App" />
</div>
</template>
<script>
import HelloWorld from "./components/HelloWorld.vue";
// Header.vueをインポート
import Header from "./components/modules/Header";
// components にHeader追加する
export default {
name: "App",
components: {
HelloWorld,
Header,
},
};
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
/* margin-top: 60px; */
}
</style>
ここまでできたら一旦確認してみましょう!!
下の画面のようにヘッダーが表示されていたらOKです!!
data:image/s3,"s3://crabby-images/1dc8c/1dc8c816a4078e6025ff58fdf2d21dfed157f391" alt="Home Lang • User
Welcome to Your Vue.js App
For a guide and recipes on how to configure / customize this project,
check Out the vue-cli documentation.
Installed CLI Plugins
Core Docs
babel eslint
Essential Links
Forum Community Chat Twitter
Ecosystem
News
vue-router
local host 8080/#
vuex vue-devtools vue-loader awesome-vue
bootstrap-btn bootstrap-vue-btn"
data:image/s3,"s3://crabby-images/1dc8c/1dc8c816a4078e6025ff58fdf2d21dfed157f391" alt="Home Lang • User
Welcome to Your Vue.js App
For a guide and recipes on how to configure / customize this project,
check Out the vue-cli documentation.
Installed CLI Plugins
Core Docs
babel eslint
Essential Links
Forum Community Chat Twitter
Ecosystem
News
vue-router
local host 8080/#
vuex vue-devtools vue-loader awesome-vue
bootstrap-btn bootstrap-vue-btn"
data:image/s3,"s3://crabby-images/de252/de2521b63daa05e0e2ee07a1d70102dd85e2665f" alt=""
data:image/s3,"s3://crabby-images/de252/de2521b63daa05e0e2ee07a1d70102dd85e2665f" alt=""
data:image/s3,"s3://crabby-images/de252/de2521b63daa05e0e2ee07a1d70102dd85e2665f" alt=""
おお!かっこいいのう!
【おまけ】ヘッダーを上部に固定させる
今のままだと、ヘッダーがスクロールすると隠れてしまいます。
もし、画面上部に固定したい場合は、Header.Vueの「b-navbar」に「fixed=”top”」を追加してください!
Header.vue
<template>
<div>
<b-navbar type="dark" variant="dark" fixed="top">
<b-navbar-nav>
<b-nav-item href="#">Home</b-nav-item>
<!-- Navbar dropdowns -->
<b-nav-item-dropdown text="Lang" right>
<b-dropdown-item href="#">EN</b-dropdown-item>
<b-dropdown-item href="#">ES</b-dropdown-item>
<b-dropdown-item href="#">RU</b-dropdown-item>
<b-dropdown-item href="#">FA</b-dropdown-item>
</b-nav-item-dropdown>
<b-nav-item-dropdown text="User" right>
<b-dropdown-item href="#">Account</b-dropdown-item>
<b-dropdown-item href="#">Settings</b-dropdown-item>
</b-nav-item-dropdown>
</b-navbar-nav>
</b-navbar>
</div>
</template>
Navsを使ってフッターを作ろう!
続いてフッターを作っていこうと思います!
フッターは、Navsを使っていきますので、気になる方はBootstrapVueでサンプルを確認してみてください!
data:image/s3,"s3://crabby-images/01566/015661fb46eb5259366819e4d14540c339c7f551" alt=""
data:image/s3,"s3://crabby-images/01566/015661fb46eb5259366819e4d14540c339c7f551" alt=""
modules配下に「Footer.vue」を作成しましょう!
data:image/s3,"s3://crabby-images/8c603/8c603e0373001f7183f1378d4e6ab32fa338b508" alt=""
data:image/s3,"s3://crabby-images/8c603/8c603e0373001f7183f1378d4e6ab32fa338b508" alt=""
Footer.vueとApp.vueを下のように変更していきましょう!
Footer.vue
<template>
<footer class="border-top">
<b-nav align="center">
<b-nav-item active>Active</b-nav-item>
<b-nav-item>Link</b-nav-item>
<b-nav-item>Another Link</b-nav-item>
<b-nav-item disabled>Disabled</b-nav-item>
</b-nav>
<p>Copyright 2021 sample.</p>
</footer>
</template>
App.vue
<template>
<div id="app">
<!-- <Header />でHeader.vueを表示 -->
<Header />
<img alt="Vue logo" src="./assets/logo.png" />
<HelloWorld msg="Welcome to Your Vue.js App" />
<!-- <Footer />でHeader.vueを表示 -->
<Footer />
</div>
</template>
<script>
import HelloWorld from "./components/HelloWorld.vue";
import Header from "./components/modules/Header";
import Footer from "./components/modules/Footer"; // add
// add Footer
export default {
name: "App",
components: {
HelloWorld,
Header,
Footer
},
};
</script>
<style>
#app {
font-family: Avenir, Helvetica, Arial, sans-serif;
-webkit-font-smoothing: antialiased;
-moz-osx-font-smoothing: grayscale;
text-align: center;
color: #2c3e50;
}
</style>
ここまでできたら確認してみましょう!!
data:image/s3,"s3://crabby-images/b83be/b83be44ce857bd3a4cde0c10c9beff9eea3108ef" alt=""
data:image/s3,"s3://crabby-images/b83be/b83be44ce857bd3a4cde0c10c9beff9eea3108ef" alt=""
うまくヘッダーが表示されたと思います!
少しボタンと被ってますが、今後ボタンは消しますのでこのままでいいかなと思います!
まとめ
今回は、BootstrapVueを使ってヘッダーとフッターを実装してみました!
学習に使った本はこちら!
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/d4c26/d4c26853b0878699d2abb201f96715781158921b" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
data:image/s3,"s3://crabby-images/bcf6a/bcf6a99ddc0f97a5472573b71d73138b0f7dba50" alt=""
Amazon Kindle Unlimited でもVue.jsの本はいっぱいあるんじゃ!!
ヘッダーとフッターがあるだけでおしゃれな画面に見えてきませんか?笑
BootstrapVueを使えば、簡単におしゃれに装飾できるので色々試してみてください!