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

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

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

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

Q&A

解決済

2回答

315閲覧

JavaScriptでのグローバル変数を定義していると、ある関数内で定義したインスタンスを別の関数で使用できるのかが分からない

1mzmk

総合スコア42

JavaScript

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

0グッド

0クリップ

投稿2022/06/30 02:53

以下のコードでstartをグローバル変数として定義していますが、DateオブジェクトのインスタンスはstartClick関数内で定義しています。
それにも関わらず、startClick関数内で定義したDateオブジェクトのインスタンスをgoTimer関数内で使用しても処理が動いてしまう理由がわかりません。
DateオブジェクトのインスタンスはstartClick関数内で定義しているのでstartClick関数外では再定義しないと使用できないという理解だったのですが。。。

startClick関数内で定義したDateオブジェクトのインスタンスをgoTimer関数内で使用しても処理が動いてしまう理由をご教授しただけると幸いです。

JavaScript

1var start; 2 3var startClick = function() { 4 var start = new Date(); 5 6 setInterval(goTimer, 1000); 7} 8 9 10 document.getElementById('start_stop').addEventListener('click', startClick, true); 11 12 var goTimer = function() { 13 var now = new Date(); 14 document.getElementById('timer').innerHTML = now.getTime() - start.getTime(); 15 } 16

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

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

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

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

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

Lhankor_Mhy

2022/06/30 03:16

ご提示のコードを試してみましたが、start が未定義であるエラーが発生しました。つまり、問題が再現しませんでした。 おそらく、ご提示の部分には原因はなさそうに思います。 ご提示いただいていない部分に原因があるか、問題の共有が上手くできていないと思います。 問題再現の手順をもう少し詳しく書いていただけますか?
Matsumon0104

2022/06/30 04:35

動作するプログラムのstartClick内の「var start = new Date()」には「var」はついていないのではないでしょうか?
guest

回答2

0

スコープに合わせた参照をするということでしょう

javascript

1const num1=1; 2const num2=1; 3{ 4const num1=2; 5const a=()=>{ 6 const num1=3; 7 const c=()=>{ 8 console.log([num1,num2]); 9 } 10 b();//[2,1] 11 c();//[3,1] 12} 13const b=()=>{ 14 console.log([num1,num2]); 15} 16a(); 17} 18

投稿2022/06/30 05:02

yambejp

総合スコア114839

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

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

0

ベストアンサー

どのように動くか、処理がうまく読み解けていないのだと思います。

処理順序は、下記のようになっています。

1.「#start_stop」をクリックする。
2.「startClick()」が実行される。
2-1.変数ブローバル「start」にDateインスタンスが作成される。
2-2.1000msに1度、goTimerが実行される。
3.「goTimer()」が実行される。(2-2より)
3-1.変数「now」にDateインスタンスが作成される。
3-2.変数「now」とグローバル変数「start」の差を求める。

javascript

1var start; 2 3var startClick = function() { // 2 4 start = new Date(); // 2-1 5 setInterval(goTimer, 1000); // 2-2 6} 7 8document.getElementById('start_stop').addEventListener('click', startClick, true); // 1 9 10var goTimer = function() { // 3 11 var now = new Date(); // 3-1 12 document.getElementById('timer').innerHTML = now.getTime() - start.getTime(); // 3-2 13}

グローバル変数はスコープが限定されないため、startClickでもgoTimerでも同じ条件で変数が利用されます。
startClickだけ、goTimerだけといったようにスコープを限定することも可能です。
let

投稿2022/06/30 04:52

Matsumon0104

総合スコア1005

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

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

1mzmk

2022/06/30 05:08

指摘いただいた通り、まさにどのように動くか、処理がうまく読み解けていませんでした。 理解することができました。 本当にありがとうございました。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問