今のところ問題は解決済みで再現もできないのですが、不思議なので質問させてください。
Laravel+Vue.jsで開発しようと悪戦苦闘中です。
Vue-Routerを使おうと下記のコードを作成しました。(app.js)
Javascript
1require('./bootstrap'); 2import Vue from 'vue'; 3import VueRouter from 'vue-router'; 4Vue.use(VueRouter); 5 6Vue.component('navbar', require('./components/Layouts/Navbar.vue').default); 7 8import index from './components/Articles/Index.vue'; 9import about from './components/About.vue'; 10 11const router = new VueRouter({ 12 mode:'history', 13 routes: [ 14 { path: '/', component: index }, 15 { path: '/about', component: about }, 16 ] 17}); 18 19const app = new Vue({ 20 router, 21 el:'#app' 22});
ところがページを表示させようとしても画面は真っ白で何も表示されません。
Chromeのコンソールを見るとUncaught TypeError: VueRouter is not a constructor
と表示されVueRouter
のインスタンス化で失敗しているみたいです。
あれこれ調べてみましたが情報も見つからず2日間解決しませんでした。
諦めかけていたときに、何となくIEで試してみたところ何故かうまく表示されました。
私は普段chromeのシークレットウィンドウを使っていますが、通常のchromeでもうまくいくみたいです。
シークレットウィンドウだけVueRouter
が失敗する原因をteratailで質問しようと作成したプログラムを修正し、静的なページを表示するだけの状態にしたところシークレットウィンドウでも表示されるようになりました。
その後プログラムを元に戻してもシークレットウィンドウで表示され、何事もなかったかのような振る舞いです。
この2日間の苦労は別に構わないのですがどうしてこんなことが起こるのか謎過ぎます。
同じ現象は再現不能になってしまいました。
フロントエンドの開発は初めてですが、こういうことはよく起こるのでしょうか?
あなたの回答
tips
プレビュー