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

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

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

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

Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

Q&A

解決済

1回答

984閲覧

vue.jsにて完成した「まるばつゲーム」が久しく開くと何故か<h2>タグしか表示されない

TMTN

総合スコア53

Vue.js

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

Vue CLI

Vue CLIは、Vue.jsでアプリケーション開発を行うためのコマンドラインインタフェース(CLI)に基づいた開発ツールです。インタラクティブなプロジェクトの雛形や設定なしで使用できるプロトタイプの作成など、さまざまな機能が用意されています。

HTML

HTMLとは、ウェブ上の文書を記述・作成するためのマークアップ言語のことです。文章の中に記述することで、文書の論理構造などを設定することができます。ハイパーリンクを設定できるハイパーテキストであり、画像・リスト・表などのデータファイルをリンクする情報に結びつけて情報を整理します。現在あるネットワーク上のほとんどのウェブページはHTMLで作成されています。

CSS

CSSはXMLやHTMLで表現した色・レイアウト・フォントなどの要素を指示する仕様の1つです。

0グッド

0クリップ

投稿2021/04/08 12:57

vue.jsにて完成した「まるばつゲーム」が久しく開くと何故か<h2>タグしか表示されない

以前こちらの「まるばつゲーム」を作成し、完成したのですが、本日Firebaseにてデプロイを実施し
ページをみてみると<h2>タグしか表示されませんでした。

githubにもpushする際にコードを誤って消したりしてしまったかもしれませんが、原因がわかりません。

分かる方お力をお借りできませんでしょうか。

よろしくお願いいたします。

エラーメッセージ

写真

<strong>We're sorry but marubatu-app doesn't work properly without JavaScript enabled. Please enable it to continue.</strong>

該当のソースコード

<template> <div> <table id="table"> <tr v-for="(row,rowsIndex) in states" :key="row.id"> <td v-for="(state,colsIndex) in row" @click="onSelect(rowsIndex, colsIndex)" :key="state.id" > <div class="maru" v-if="state==1">○</div> <div class="batu" v-if="state==2">×</div> </td> </tr> </table> <div class="player"> <div class="player-maru" v-if="playerId==1">「○ プレイヤーさん、マスを選んでください」</div> <div class="player-batu" v-if="playerId==2">「× プレイヤーさん、マスを選んでください」</div> </div> <div class="winner" v-if="winnerText"> <p v-text="winnerText"></p> <img src="../assets/winner.jpg" /> </div> </div> </template> <script> export default { data() { return { states: [], playerId: 1, winnerText: "" }; }, methods: { init: function() { this.states = [ [-1, -1, -1], [-1, -1, -1], [-1, -1, -1] ]; }, onSelect: function(rowsIndex, colsIndex) { this.winnerText = ""; if (this.states[rowsIndex][colsIndex] != -1) { alert("そのマスは、すでに選択されています!"); } else { let states = JSON.parse(JSON.stringify(this.states)); //JSONに再度元に戻す states[rowsIndex][colsIndex] = this.playerId; this.states = states; //再度代入 this.playerId = this.playerId == 1 ? 2 : 1; //三項演算子 let winnerId = this.getWinnerId(); if (winnerId != -1) { this.init(); let playerIds = { 1: "○", 2: "×" }; this.winnerText = playerIds[winnerId] + " さんの勝ちです。おめでとうございます!"; } else if (this.isDraw()) { this.init(); alert("引き分けです!"); } } }, getWinnerId: function() { for (let i = 0; i < 3; i++) { // 横の列 let row = this.states[i]; if (this.isStatesFilled(row)) { return row[0]; } // 縦の列 let col = [this.states[0][i], this.states[1][i], this.states[2][i]]; if (this.isStatesFilled(col)) { return this.states[0][i]; } } // ななめ let skew1 = [this.states[0][0], this.states[1][1], this.states[2][2]]; if (this.isStatesFilled(skew1)) { return this.states[0][0]; } let skew2 = [this.states[0][2], this.states[1][1], this.states[2][0]]; if (this.isStatesFilled(skew2)) { return this.states[0][2]; } return -1; }, isStatesFilled: function(states) { return ( states[0] != -1 && states[0] == states[1] && states[1] == states[2] ); }, isDraw: function() { for (let i in this.states) { let row = this.states[i]; for (let j in row) { let state = row[j]; if (state == -1) { return false; } } } return true; } }, mounted: function() { this.init(); } }; </script> <style lang="scss"> #table { margin: 0 auto; border-collapse: collapse; border: 3px solid #ccc; td { border: 1px solid #ccc; height: 110px; width: 110px; text-align: center; vertical-align: middle; font-size: 80px; cursor: pointer; .maru { color: #f00; } .batu { color: #00f; } } } .player { text-align: center; font-weight: bold; font-size: 16px; padding: 20px; &-maru { color: #f00; } &-batu { color: #00f; } } .winner { text-align: center; font-weight: bold; font-size: 30px; img { width: 220px; height: 220px; } } </style>

試したこと

ここに問題に対して試したことを記載してください。

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

ここにより詳細な情報を記載してください。

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

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

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

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

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

guest

回答1

0

自己解決

コンポーネントで作成していたのですが、<router-view>で指定しておりました。
変更したら上手く反映されました。

投稿2021/04/08 14:37

TMTN

総合スコア53

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問