addEventListenerがnullになる
受付中
回答 1
投稿
- 評価
- クリップ 0
- VIEW 339
どっどインストールのレッスンを模写しております。ストップウォッチを作りたいです。
まず、startをクリックしたら....のイベントリスターがnullになります。
どっどインストールのソースコードをそのまま貼り付けてもnullになり、ボタンを押しても動きません。
どなたか助けていただきたいです。
私のコード
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>Stopwatch</title>
<script>
'use strict';
var timer = document.getElementById('timer');
var start = document.getElementById('start');
var stop = document.getElementById('stop');
var reset = document.getElementById('reset');
var startTime;
function countUp() {
var d = new Date(Date.now() - startTime);
var m = String(d.getMinutes()).padStart(2, '0');
var s = String(d.getSeconds()).padStart(2, '0');
var ms = String(d.getMilliseconds()).padStart(3, '0');
timer.textContent = ${m}:${s}.${ms}
;
setTimeout(() => {
countUp();
}, 10);
}
start.addEventListener('click', () => {
startTime = Date.now();
countUp();
});
</script>
</head>
<body>
<div id="timer">00:00.000</div>
<button id="start">Start</button>
<button id="stop">Stop</button>
<button id="reset">Reset</button>
</body>
</html>
試したこと、
addEventListenerの上に、window.onload=()=>
を付けましたが、変わりませんでした。
-
気になる質問をクリップする
クリップした質問は、後からいつでもマイページで確認できます。
またクリップした質問に回答があった際、通知やメールを受け取ることができます。
クリップを取り消します
-
良い質問の評価を上げる
以下のような質問は評価を上げましょう
- 質問内容が明確
- 自分も答えを知りたい
- 質問者以外のユーザにも役立つ
評価が高い質問は、TOPページの「注目」タブのフィードに表示されやすくなります。
質問の評価を上げたことを取り消します
-
評価を下げられる数の上限に達しました
評価を下げることができません
- 1日5回まで評価を下げられます
- 1日に1ユーザに対して2回まで評価を下げられます
質問の評価を下げる
teratailでは下記のような質問を「具体的に困っていることがない質問」、「サイトポリシーに違反する質問」と定義し、推奨していません。
- プログラミングに関係のない質問
- やってほしいことだけを記載した丸投げの質問
- 問題・課題が含まれていない質問
- 意図的に内容が抹消された質問
- 過去に投稿した質問と同じ内容の質問
- 広告と受け取られるような投稿
評価が下がると、TOPページの「アクティブ」「注目」タブのフィードに表示されにくくなります。
質問の評価を下げたことを取り消します
この機能は開放されていません
評価を下げる条件を満たしてません
質問の評価を下げる機能の利用条件
この機能を利用するためには、以下の事項を行う必要があります。
- 質問回答など一定の行動
-
メールアドレスの認証
メールアドレスの認証
-
質問評価に関するヘルプページの閲覧
質問評価に関するヘルプページの閲覧
0
ドットインストールの JavaScriptでストップウォッチを作ろう (全12回) ってやつですね。最初の 3 回は無料なので見てみましたが、index.html と js/main.js を別々のファイルに書くことになってるようです。
実際には一つのファイルにまとめて書くこともできますが、重要なのは <script> タグの位置です。質問文のように <head> 〜 </head> の中に <script> タグを書くと、そのスクリプトは <body> が読み込まれる前に実行されてしまい、<body> の中にある <div id="timer">00:00.000</div> などはまだ存在しないので、document.getElementById('timer') などが nullになってしまいます。
動画では第 1 回の中で「ボディの閉じタグの直前に」と言ってる(特に理由は説明してませんが)ように、<script> は </body> の直前に書くといいでしょう。
<!DOCTYPE html>
<html lang="ja">
<head>
<meta charset="utf-8">
<title>Stopwatch</title>
</head>
<body>
<div id="timer">00:00.000</div>
<button id="start">Start</button>
<button id="stop">Stop</button>
<button id="reset">Reset</button>
<script>
'use strict';
var timer = document.getElementById('timer');
// 以下略
</script>
</body>
</html>
投稿
-
回答の評価を上げる
以下のような回答は評価を上げましょう
- 正しい回答
- わかりやすい回答
- ためになる回答
評価が高い回答ほどページの上位に表示されます。
-
回答の評価を下げる
下記のような回答は推奨されていません。
- 間違っている回答
- 質問の回答になっていない投稿
- スパムや攻撃的な表現を用いた投稿
評価を下げる際はその理由を明確に伝え、適切な回答に修正してもらいましょう。
15分調べてもわからないことは、teratailで質問しよう!
- ただいまの回答率 88.33%
- 質問をまとめることで、思考を整理して素早く解決
- テンプレート機能で、簡単に質問をまとめられる
質問への追記・修正、ベストアンサー選択の依頼
m.ts10806
2020/03/24 22:19
コードはマークダウンのcode機能を利用してご提示ください。
また、質問は編集できますので、新たに投稿しなおす必要はありません。
片方削除依頼を出しておいてください
m.ts10806
2020/03/24 22:21
code機能の対応のさせかたの例:
https://teratail.com/questions/238564
使えるマークダウン:
https://teratail.com/help#about-markdown
いずれにしても、コード部分がマークダウン対応されてないと読む気をなくす回答者も多いので覚えておかないと損しかないです。
m.ts10806
2020/03/24 22:25
ドットインストールやったことないのですけど、
読み込みと実行順、DOM構築の仕組みを全く触れないんでしょうか。
いずれにしても・・・
要素が出現してない状態でgetしようとしても存在しないのは一般的に考えて当然ですよね。