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

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

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

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

Q&A

解決済

2回答

1095閲覧

【javascriptエラー】Uncaught ReferenceError: 定数名 is not definedで、正答率を表示させることができない

begine

総合スコア7

JavaScript

JavaScriptは、プログラミング言語のひとつです。ネットスケープコミュニケーションズで開発されました。 開発当初はLiveScriptと呼ばれていましたが、業務提携していたサン・マイクロシステムズが開発したJavaが脚光を浴びていたことから、JavaScriptと改名されました。 動きのあるWebページを作ることを目的に開発されたもので、主要なWebブラウザのほとんどに搭載されています。

0グッド

0クリップ

投稿2020/06/30 13:10

編集2020/07/01 05:34

前提・実現したいこと

クイズ結果に正答率を表示させようと調べながらコードを書いていったのですが、以下のエラーが発生して結果画面が表示しなくなってしまいました。

(※書き足したコードの行にコメントで仮と書いています。)

よろしくお願いします。

発生している問題・エラーメッセージ

Uncaught ReferenceError: accuracy is not defined at HTMLDivElement.<anonymous>

該当のソースコード

html

1 2 3 <section class="container3"> 4 <div id="timer">00:00.00</div> <!--カウントダウンタイマーを表示--> 5 <div hidden id="correct"></div> <!-- 仮 --> 6 <div hidden id="wrong"></div> <!-- 仮 --> 7 </section> 8 9

javascript

1 2 3 4 const correct = document.getElementById('correct'); // 仮 5 const wrong = document.getElementById('wrong'); // 仮 6 7 function countDown() { 8 timerId = setTimeout (function() { 9 timeLeft = timeToCountDown - (Date.now() - startTime); 10 11 12 if(timeLeft < 0){ 13 clearTimeout(timerId); 14 timeLeft = 0; 15 16 updateTimer(timeLeft); 17 18 btn.classList.remove('disabled'); 19 btn.textContent = '結果発表'; 20 currentNum = quizSet.length - 1; 21 isAnswered = true; 22 return; 23 } 24 25 updateTimer(timeLeft); 26 countDown(); 27 showResult(); // 仮 28 }, 10); 29 } 30 31 32 function showResult(){ // 仮 33 const accuracy = correct + wrong === 0 ? 0 : correct / (correct + wrong) * 100; 34 } 35 36 btn.addEventListener('click', () => { 37 if (btn.classList.contains('disabled')) { 38 return; 39 } 40 btn.classList.add('disabled'); 41 42 if (currentNum === quizSet.length - 1) { 43 scoreLabel.innerHTML = `${quizSet.length} <br> 44 ${score}<br> 45 ${accuracy.toFixed(2)}%`; // 仮 46 result.classList.remove('hidden'); 47 } else { 48 currentNum++; 49 setQuiz(); 50 } 51 }); 52} 53

試したこと

エラー文を検索してコード間違いを探したのですが、解決することができません。

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

ブロック内で以下のように記述したら解決できました。

javascript

1 showResult(); // 仮 2 3 function showResult(){ // 仮 4 const accuracy = correct + wrong === 0 ? 0 : correct / (correct + wrong) * 100; 5 if (currentNum === quizSet.length - 1) { 6 scoreLabel.innerHTML = `${quizSet.length} <br> 7 ${score} <br> 8 ${accuracy.toFixed(2)}%`; //仮 9 result.classList.remove('hidden'); 10 } else { 11 currentNum++; 12 setQuiz(); 13 } 14 } 15 }); 16}

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

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

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

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

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

yambejp

2020/07/01 01:12

肥大化したプログラムをまるっと載せて質問するのはナンセンス 機能を関数化して、それぞれの関数について入出力と動作を決め込んでいけば 質問自体はその関数だけ例示すれば可能です
begine

2020/07/01 05:33

わかりました。 次回から気をつけます。
guest

回答2

0

ベストアンサー

javascript

1 function showResult(){ // 仮 2 const accuracy = correct + wrong === 0 ? 0 : correct / (correct + wrong) * 100; 3 }

constブロックスコープですので、accuracyが有効なのはこの関数の中だけです。

投稿2020/06/30 13:19

maisumakun

総合スコア145184

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

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

begine

2020/07/01 05:32 編集

ありがとうございます、エラーを消すことができました。 補足に解決方法を追記しました。
guest

0

google翻訳
Uncaught ReferenceError:accuracyが定義されていません

その名前の変数/定数が定義されてないとおっしゃってますよ。

投稿2020/06/30 13:15

y_waiwai

総合スコア87774

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

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

begine

2020/07/01 05:35 編集

ありがとうございます、解決できました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問