質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Router

Routerは、異なるネットワーク同士を相互に接続するための通信機器。インターネットでのデータを自動的に振り分け、一つのインターネット回線を複数のコンピュータで使用することが可能です。DHCPによりIPアドレスを自動的に割振りすることもできます。

Vuetify.js

Vuetify.jsは、マテリアルデザインを基本とするVue.jsのCSSフレームワークです。多くのマテリアルデザインのコンポーネントを提供しており、あらゆるアプリケーションに対応可能。vue-cli用テンプレートがあり、簡単にページを作成できます。

Q&A

解決済

1回答

3328閲覧

vue-routerで画面遷移がしたい(ページの切り替えがしたい)

arcu

総合スコア4

Vue.js

Vue.jsは、Webアプリケーションのインターフェースを構築するためのオープンソースJavaScriptフレームワークです。

Router

Routerは、異なるネットワーク同士を相互に接続するための通信機器。インターネットでのデータを自動的に振り分け、一つのインターネット回線を複数のコンピュータで使用することが可能です。DHCPによりIPアドレスを自動的に割振りすることもできます。

Vuetify.js

Vuetify.jsは、マテリアルデザインを基本とするVue.jsのCSSフレームワークです。多くのマテリアルデザインのコンポーネントを提供しており、あらゆるアプリケーションに対応可能。vue-cli用テンプレートがあり、簡単にページを作成できます。

0グッド

0クリップ

投稿2020/11/13 12:48

前提・実現したいこと

VueとVuetifyで画像投稿アプリを作っています。(まずはUIを作成中です。)
vue-routerで画面遷移をする際に遷移元の画面が残ってしまいます。完全に画面を別のページへ遷移させる方法はありますでしょうか。
具体的には、App.vueのContentコンポーネントでカード形式で画像の一覧を並べており、個々の画像をクリックすることでContentDetailコンポーネントの詳細画面に遷移させたいのですが、<router-view />の位置からもわかる通り、ContentDetailコンポーネントが表示された下部にContentコンポーネントのカード一覧が残ってしまう状況です。
詳細のページを表示する際は、カード一覧のページを表示させないように画面遷移したいのですが、方法がわからないため、ご教授頂けますと幸いです。

該当のソースコード

App.vue

vue

1<template> 2 <v-app dark> 3 <Header /> 4 <router-view /> 5 <div class="content-wrapper"> 6 <v-row> 7 <v-col v-for="i in 6" :key="i" cols="12" sm="6" md="4" lg="3"> 8 <Content /> 9 </v-col> 10 </v-row> 11 <Modal /> 12 </div> 13 </v-app> 14</template> 15 16<script> 17import Content from "./components/Content.vue"; 18import Header from "./components/Header.vue"; 19import Modal from "./components/Modal.vue"; 20 21export default { 22 components: { Content, Header, Modal }, 23}; 24</script>

Content.vue

vue

1<template> 2 <v-card 3 class="v-card mx-auto" 4 max-width="1000" 5 tile 6 :to="{ name: 'detailPage' }" 7 > 8 <v-img 9 src="https://cdn.vuetifyjs.com/images/cards/sunshine.jpg" 10 height="200px" 11 > 12 <div class="fill-height bottom-gradient"></div> 13 </v-img> 14 <v-card-title> 15 Top western road trips 16 </v-card-title> 17 <v-card-subtitle> 18 1,000 miles of wonder 19 </v-card-subtitle> 20 21 </v-card> 22</template>

ContentDetail.vue

vue

1<template> 2 <div> 3 <v-app> 4 5 <v-carousel cycle hide-delimiters> 6 <v-carousel-item 7 v-for="(item, i) in items" 8 :key="i" 9 :src="item.src" 10 ></v-carousel-item> 11 </v-carousel> 12 <div class="detailtext"> 13 <h2>タイトル</h2> 14 <p> 15 詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント 16 詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント 17 詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント 18 詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント詳細コメント 19 </p> 20 </div> 21 </v-app> 22 </div> 23</template> 24 25<script> 26export default { 27 data() { 28 return { 29 items: [ 30 { 31 src: "https://cdn.vuetifyjs.com/images/carousel/squirrel.jpg", 32 }, 33 { 34 src: "https://cdn.vuetifyjs.com/images/carousel/sky.jpg", 35 }, 36 { 37 src: "https://cdn.vuetifyjs.com/images/carousel/bird.jpg", 38 }, 39 { 40 src: "https://cdn.vuetifyjs.com/images/carousel/planet.jpg", 41 }, 42 ], 43 }; 44 }, 45}; 46</script>

js

1import Vue from "vue"; 2import Router from "vue-router"; 3import ContentDetail from "@/components/ContentDetail.vue"; 4 5Vue.use(Router); 6 7export default new Router({ 8 mode: "history", 9 routes: [ 10 { 11 path: "/detail", 12 name: "detailPage", 13 component: ContentDetail, 14 }, 15 ], 16}); 17

試したこと

表示位置が怪しいと思い、<router-view />の位置を変えたりして見ましたが、App.vueのどこに配置しても他のコンポーネントも描写されてされてしまいました。(当たり前ですが、、、)

補足情報(FW/ツールのバージョンなど)

"core-js": "^3.6.5",
"vue": "^2.6.11",
"vue-router": "^3.4.9",
"vuetify": "^2.2.11"

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

App.vue に書くとすべてのページに表示されるのは仕様です。

{ path: '/', name: 'Home', component: Home, },

こんな感じにrouteを貼ってあげて、
detailページと同じように、一覧表示するためのページを作りましょう。

投稿2020/11/13 14:31

編集2020/11/13 14:32
hukurouo

総合スコア108

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

arcu

2020/11/13 16:08

>App.vue に書くとすべてのページに表示されるのは仕様です。 ご指摘の通り、この仕様を知らなかったことが原因でした。App.vueには最低限の記述のみ行い、他のコンポーネントに移動し、routeを貼ることで解決いたしました。5時間ほど悩んでましたので大変助かりました。ありがとうございます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問