0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

【vue+webpack】単一コンポーネント(.vue)での簡易的なルーティング

Posted at

##状況
クライアントサイドのフレームワークは入門レベル。
現在vue+webpackでチュートリアル以降、自分用アプリを作って練習中。

##やったこと
SPAはちょっとまだいいかなと思ってvue-routerは入れなかったんだけど、若干ルーティング的なことがしたくなった。
.vueファイルを使う単一コンポーネントの場合にそのまま使える例がみつからなかったので、自力でできるだけ簡単に実装した。

##環境
vue-cliで作成。

vue -V
2.9.6
vue init webpack xxx

##内容
###フォルダ構成
生成されるファイル群のうちsrcフォルダ内のみ表示。

D:.
│  App.vue
│  main.js
│  simpleRouter.js ←ルーティング情報を持つ
│
├─assets
│      logo.png
│
└─components
        cmpA.vue ←ルーティング先
        cmpB.vue ←ルーティング先
        cmpC.vue ←ルーティング先
        cmpP.vue ←親

###動き
押すとふつうに切り替わる感じ。親コンポーネントと呼んではいるものの、移動はページ単位。

初期表示
1_ini.PNG

[cmpAを表示]クリック
2_A.PNG

[cmpBを表示]クリック
3_B.PNG

[cmpCを表示]クリック
4_C.png

###ソース

####ルーター
といっても実際に飛ばす動きはしないので単にルーティングテーブルみたいな感じか。
リンク先のパス名とコンポーネントを持たせる。

simpleRouter.js
import A from './components/cmpA'
import B from './components/cmpB'
import C from './components/cmpC'

export default {
    '/A': A,
    '/B': B,
    '/C': C
}

####リンク先になるコンポーネントファイルたち

cmpA.vue
<template>
    <div>コンポーネントA</div>
</template>

<script>
export default {
    
}
</script>

<style scoped>
div {
    color:green;
}
</style>

cmpB.vue
<template>
    <div>コンポーネントB</div>
</template>

<script>
export default {
    
}
</script>

<style scoped>
div {
    color:blue;
}
</style>

cmpC.vue
<template>
    <div>コンポーネントC</div>
</template>

<script>
export default {
    
}
</script>

<style scoped>
div {
    color:red;
}
</style>

####呼び出し元になるコンポーネントファイル
ここで実際にルーティング。
単純にパス名取ってルーティングテーブルからコンポーネントを引っ張る。

cmpP.vue
<template>
    <div id="Parent">
        <a href="/">親コンポーネント</a><br/>
        <a href="/A">cmpAを表示</a>
        <a href="/B">cmpBを表示</a>
        <a href="/C">cmpCを表示</a>
        <component :is="cmp"/>
    </div>
</template>

<script>
import simpleRouter from '../simpleRouter.js'

export default {
    data() {
        return {
            cmp: simpleRouter[window.location.pathname],
        }
    }
}

window.addEventListener('popstate', () => {
  app.currentRoute = window.location.pathname
})
</script>

##おわり
自分用なのでこのくらいで十分ですね。部分的な更新とかぬるぬる遷移するようなやつはまた別にやりましょう。
Not Foundくらいは対応しないといけないと思う。

0
0
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
0
0

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?