ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
| この記事の要点 |
|
Vue Router のデフォルト挙動
Vue Router を使ったプロジェクトでは が現在ルートにマッチした要素に自動でクラスを付与します:
router-link-active— そのリンク先 (またはサブパス) にいる場合router-link-exact-active— そのリンク先と完全一致している場合
最小構成
これだけで /about にいるときに "About" だけがハイライトされます。
active と exact-active の違い
| 現在 URL | リンク to="/" | リンク to="/products" |
|---|---|---|
/ | active + exact-active | - |
/products | active | active + exact-active |
/products/123 | active | active のみ (exact 不一致) |
つまり router-link-active は前方一致、router-link-exact-active は完全一致です。
クラス名のグローバル変更
// router/index.js (Vue Router 4)
import { createRouter, createWebHistory } from 'vue-router';
const router = createRouter({
history: createWebHistory(),
routes: [/* ... */],
linkActiveClass: 'is-active',
linkExactActiveClass: 'is-current',
});
export default router;/* CSS 側もこれで参照 */
nav a.is-active { color: #f4c430; }
nav a.is-current { background: #fffbea; }
リンク単位のカスタマイズ
About
computed + $route で完全制御
サブメニュー / ボタン / フッターなど 以外の要素でハイライトしたい場合:
ネストルートでの挙動
子ルートにいるとき親リンクも active になります:
// routes
{
path: '/products',
component: ProductsLayout,
children: [
{ path: '', component: ProductsIndex },
{ path: ':id', component: ProductDetail },
],
}
// /products/123 にいるとき
// は router-link-active が付く (前方一致)
// は exact-active も付く
動的なルートに対する判定
-
{{ cat.name }}
Nuxt 3 の場合
Nuxt 3 は が同等の動作をします。クラス名も同じ router-link-active / router-link-exact-active:
Nuxt 3.4+ では activeClass / exactActiveClass プロップで変更可能:
About
クエリパラメータ違いを区別したい
標準の active 判定はパスのみ。クエリも含めたい場合は手動:
書籍
CSS で表現の工夫
/* 下線で示す */
nav a.router-link-active {
position: relative;
}
nav a.router-link-active::after {
content: '';
position: absolute;
left: 0; right: 0; bottom: -2px;
height: 2px;
background: #f4c430;
}
/* バッジで示す */
nav a.router-link-exact-active::before {
content: '●';
color: #f4c430;
margin-right: 4px;
}
/* スムーズなトランジション */
nav a {
transition: color .2s, border-color .2s;
}
FAQ
Q: / リンクが全ページで active になる
A: 旧 Vue Router 3 の挙動。exact プロップを付けるか、Vue Router 4 にアップグレード (4 では exact-active が独立クラス化)。
Q: ハイライトが付かない
A: が描画する 要素にクラスが付く。CSS で nav a.router-link-active のようにセレクタを正しく指定。
Q: SSR / Hydration で初期表示時にハイライトが消える
A: Nuxt 3 / Vue Router 4 のサーバ側も useRoute() を解決するので問題なし。ハイライトが消える場合は CSS のスコープ問題を疑う。
Q: アンカーリンク (#section) もハイライトしたい
A: ハッシュは route.hash で取れる。:class="{ active: route.hash === "#section" }" で判定。
ページの作成
親となるページを選択してください。
親ページに紐づくページを子ページといいます。
例: 親=スポーツ, 子1=サッカー, 子2=野球
子ページを親ページとして更に子ページを作成することも可能です。
例: 親=サッカー, 子=サッカーのルール
親ページはいつでも変更することが可能なのでとりあえず作ってみましょう!
子ページはありません
- インストール(ファイルのダウンロード)
- npmを使用したプロジェクトの作成(mac)
- for 繰り返し処理
- ifの条件分岐とtemplateを用いたグループ化
- on:click クリック時のイベント処理
- modelとdata フォーム入力値とDOMへの即時反映
- computed(算出プロパティ)と使い方とdataとの違い
- ライフサイクルフック(created / mounted / updated / destroyedの使い方)
- $nextTickの使い方(ライフサイクルフック)
- メソッドの定義方法
- エラー一覧
- ルーティング設定
- aリンクの貼り方と動的URLの作成
- Mixinを利用した共通処理の記述方法
- v-bindによるデータ連携
- ヘッダー/フッターの共通コンポーネント
- ナビゲーションの現在ページをハイライトする方法
- 画面サイズの取得方法
人気ページ
- 1 Eclipseで「サーバーに追加または除去できるリソースがありません。」の原因と対処法
- 2 tomcat の起動 / 停止ログと catalina.log・catalina.out の違い
- 3 JavaScript base URL 取得方法|window.location.origin と SSR/Node.js 対応
- 4 YouTube Data API v3 エラー一覧|403/400/404 の主要原因と切り分け
- 5 Spring Frameworkのアノテーション一覧
- 6 Laravel エラー一覧|500/Blade/DB 接続/ルーティングの代表エラー
- 7 3Dグラフィックスとは|モデリング/レンダリング/主要ソフトウェア (Blender / Maya)
- 8 【Spring】@Valueアノテーションとは
- 9 CATALINA_HOME の確認方法 (Linux / Mac)
- 10 【Spring】@Autowiredアノテーションとは
最近更新/作成されたページ
- Laravel キャッシュクリア完全ガイド(cache:clear / config:clear / 2026-05-18 07:42:07
- プロジェクトの作成と削除 2026-05-18 07:42:07
- インストール直後にNetbeansが反応しない 2026-05-18 07:42:07
- 動画やチャンネルの検索 2026-05-18 07:42:07
- APIキー取得方法 2026-05-18 07:42:07
- チャンネル情報の取得 2026-05-18 07:42:07
- API 入門 — Web API(REST / GraphQL / gRPC / 2026-05-18 07:42:07
- インストール(eclipseプラグイン) 2026-05-18 07:42:07
- Laravel「Dotenv values containing spaces must be surrounded 2026-05-18 07:42:07
- エラー一覧 2026-05-18 07:42:07
- curl: (51) SSL: certificate subject name '~' does not match 2026-05-18 07:42:07
- インストール方法(Windows版) 2026-05-18 07:42:07
- JSONから配列に変換 2026-05-18 07:42:07
- 処理を一定時間待つ 2026-05-18 07:42:07
- A non well formed numeric value encountered 2026-05-18 07:42:07
コメントを削除してもよろしいでしょうか?