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

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

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

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

Router

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

Q&A

解決済

1回答

2569閲覧

Vueでnotfoundページを作ったが、RailsのRouting Errorが表示されてしまう

ko-u

総合スコア61

Vue.js

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

Router

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

Ruby on Rails

Ruby on Railsは、オープンソースのWebアプリケーションフレームワークです。「同じことを繰り返さない」というRailsの基本理念のもと、他のフレームワークより少ないコードで簡単に開発できるよう設計されています。

0グッド

0クリップ

投稿2020/03/02 01:04

編集2020/03/02 01:05

現在自主学習として、RailsとVueでSPAアプリケーションを作っています。

vue-routerで404ページを作りたく、以下のようにpathが設定されているもの以外はNotFoundコンポーネントを表示させるようにしました。

しかし、RailsのRouting Errorが表示されてしまいます。

router.js

js

1import Vue from 'vue' 2import Router from 'vue-router' 3 4   ・ 5   ・ 6   ・ 7 8import NotFound from '../components/notFound' 9 10Vue.use(Router) 11 12export default new Router({ 13 mode: 'history', 14 routes: [ 15 16   ・ 17   ・ 18   ・ 19 20 // うまくリダイレクトされていない 21 { 22 path: '*', 23 component: NotFound, 24 } 25 ] 26})

app.vue

js

1<template> 2 <v-app id="inspire"> 3 <Header/> 4 <router-view> 5 </router-view> 6 </v-app> 7</template> 8 9<script> 10 import Header from "./components/Header"; 11 12 export default { 13 components: { 14 Header, 15 }, 16 } 17</script> 18

どんな些細なことでもよろしいので、ご教示頂けますと幸いです。
よろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

Vue.js のルーティングと Rails のルーティングの概念を整理されたほうがいいと思います。

Vue.js のルーティングはrouter-linkや Vue Router のメソッドを使った場合に有効になります。
通常のaタグをクリックしたり、ページをリロードするとサーバー、つまり Rails へリクエストが飛んでそちらでルーティングが解決されます。

今はこの 2つのルーティングを混同されているように思いました。

もし後者の場合でも Vue Router でルーティングを解決したい場合は、Rails の 404 ページに Vue.js のコンポーネントを埋め込むか、Vue.js のコンポーネントがあるページにリダイレクトする必要があると思います。
(ただ、Vue Router で解決するべきリクエストが Rails へ到達している点は設計レベルで課題がある気もします)

おそらくこちらの記事が参考になると思います。
Rails+Vue+VueRouterでhistoryモード時に直接表示で404エラーになってしまう対策方法 サシミスタジオ

個人的には Vue Router を使うのであれば、その部分は Rails と独立させたほうが実装が整理されてシンプルになることが多いと思っています。
例えば、フロントエンドを Vue.js + Vue Router で実装して、Rails を API として使うといった方法などがあります。
とはいえ、これは要件やスキルセットによるので、ご自身でいろいろ実装してベターな構成や方法を見つけていただければと思います。

投稿2020/03/03 05:05

shgtkshruch

総合スコア665

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問