docker+vite+vue3環境の構築
まず、ここを参考にdockerで構築してください。
docker compose upで初期ページが起動するところまで。
Bootstrapのインストール
以下を参考にしますが、書いてある通りだとうまくいかない。
npmではなくyarnでセットアップしていきます。
- Bootstrap本体とpopperjs
docker compose exec frontend yarn add bootstrap @popperjs/core
- sass
docker compose exec frontend yarn add sass
- scssファイルを作成
docker compose exec frontend touch src/assets/styles.scss
- scssファイルを編集
./assets/styles.scss
// Import all of Bootstrap's CSS
@import "bootstrap/scss/bootstrap"
動作確認
- 確認用のページBootstrap.vueを作成
docker compose exec frontend touch Bootstrap.vue
- Bootstrap.vueを以下のように編集
Bootstrap.vue
<template>
<div class="container py-4 px-3 mx-auto">
<h1>Hello, Bootstrap and Vite!</h1>
<button class="btn btn-primary">Primary button</button>
<h1>
<i class="bi bi-0-circle" ></i>
<i class="bi bi-facebook"></i>
</h1>
</div>
</template>
- 確認のためmain.jsでBootstrap.vueを読み込むように変更。
main.js
import './assets/main.css'
import { createApp } from 'vue'
import { createPinia } from 'pinia'
- import App from './App.vue'
+ import App from './Bootstrap.vue'
import router from './router'
const app = createApp(App)
app.use(createPinia())
app.use(router)
app.mount('#app')
- ブラウザで確認
まだscssを読み込んでいないので、bootsrapぽさはありません。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F82975%2Fcf1fda55-92ba-8a45-455b-df8bba898a6f.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=143098e1228abc7cdced2546de1a3a71)
scssのインポート
- main.jsにscssをインポートします。
main.js
import './assets/main.css'
+ import './assets/styles.scss'
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
import router from './router'
const app = createApp(App)
app.use(createPinia())
app.use(router)
app.mount('#app')
- Bootstrapらしくなりました
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F82975%2F440923e1-27e5-a419-e53d-7a982234fbb5.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=73b74969c9faa264a800beec1971b3d1)
Navbarの確認
- Bootstrap.vueにNavbarを追加
Bootstrap.vue
<template>
<nav class="navbar navbar-expand-lg bg-body-tertiary">
<div class="container-fluid">
<a class="navbar-brand" href="#">Navbar</a>
<button class="navbar-toggler" type="button" data-bs-toggle="collapse" data-bs-target="#navbarSupportedContent" aria-controls="navbarSupportedContent" aria-expanded="false" aria-label="Toggle navigation">
<span class="navbar-toggler-icon"></span>
</button>
<div class="collapse navbar-collapse" id="navbarSupportedContent">
<ul class="navbar-nav me-auto mb-2 mb-lg-0">
<li class="nav-item">
<a class="nav-link active" aria-current="page" href="#">Home</a>
</li>
<li class="nav-item">
<a class="nav-link" href="#">Link</a>
</li>
<li class="nav-item dropdown">
<a class="nav-link dropdown-toggle" href="#" role="button" data-bs-toggle="dropdown" aria-expanded="false">
Dropdown
</a>
<ul class="dropdown-menu">
<li><a class="dropdown-item" href="#">Action</a></li>
<li><a class="dropdown-item" href="#">Another action</a></li>
<li><hr class="dropdown-divider"></li>
<li><a class="dropdown-item" href="#">Something else here</a></li>
</ul>
</li>
<li class="nav-item">
<a class="nav-link disabled" aria-disabled="true">Disabled</a>
</li>
</ul>
<form class="d-flex" role="search">
<input class="form-control me-2" type="search" placeholder="Search" aria-label="Search">
<button class="btn btn-outline-success" type="submit">Search</button>
</form>
</div>
</div>
</nav>
<div class="container py-4 px-3 mx-auto">
<h1>Hello, Bootstrap and Vite!</h1>
<button class="btn btn-primary">Primary button</button>
<h1>
<i class="bi bi-0-circle" ></i>
<i class="bi bi-facebook"></i>
</h1>
</div>
</template>
- Navbarがつきましたが、BootstrapJSがまだ読み込まれていないのでDropdownが効いていません。
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F82975%2F8347254b-3ea0-1f85-3312-c0a80b46ddb8.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=6d460249f446073bcff365e1b8043a14)
- BootstrapJSの有効化
main.jsに追加
main.js
import './assets/main.css'
import './assets/styles.scss'
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
import router from './router'
+ // Import all of Bootstrap's JS
+ import * as bootstrap from 'bootstrap'
const app = createApp(App)
app.use(createPinia())
app.use(router)
app.mount('#app')
- ドロップダウンも有効になりました
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F82975%2F9f0f3e2f-93ca-d346-d5ec-d72ec745b837.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=1db14cedd8724762aa896e9184e656f4)
Bootstrap Iconsのインストール
ついでなので、Bootstrap Iconsもインストールしてみましょう。
- インストール
docker compose exec frontend yarn add bootstrap-icons
- main.jsに読み込み
main.js
import './assets/main.css'
import './assets/styles.scss'
import { createApp } from 'vue'
import { createPinia } from 'pinia'
import App from './App.vue'
import router from './router'
// Import all of Bootstrap's JS
import * as bootstrap from 'bootstrap'
+ // Import Bootstrap-Icons
+ import 'bootstrap-icons/font/bootstrap-icons.css'
const app = createApp(App)
app.use(createPinia())
app.use(router)
app.mount('#app')
- Bootstrap Iconは以下のように使用します
<i class="bi-alarm" style="font-size: 2rem; color: cornflowerblue;"></i>
- 確認
![](https://qiita-user-contents.imgix.net/https%3A%2F%2Fqiita-image-store.s3.ap-northeast-1.amazonaws.com%2F0%2F82975%2Fa7e2230e-7c58-c414-7cf0-7adb7e03add5.png?ixlib=rb-4.0.0&auto=format&gif-q=60&q=75&s=9c70d405c73be22ecef652b6eb12eca0)