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

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

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

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

GsACADEMY

セカイを変えるエンジニア【GEEK】を養成する 授業料後払いのエンジニア養成学校です。 ①一流企業によるメンター指導 基本習得後は2ヶ月間メンターの個別指導でサービス完成を目指します。 ②480万円までの起業支援出資 起業志望者をサムライインキュベートが支援(審査あり)します。 ③初心者歓迎・授業料後払い 丸暗記ではなく、創りながら。初心者のための授業料後払い制度です。

Q&A

解決済

1回答

5257閲覧

画像を5回点滅させる

HirokiNakajima

総合スコア28

JavaScript

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

GsACADEMY

セカイを変えるエンジニア【GEEK】を養成する 授業料後払いのエンジニア養成学校です。 ①一流企業によるメンター指導 基本習得後は2ヶ月間メンターの個別指導でサービス完成を目指します。 ②480万円までの起業支援出資 起業志望者をサムライインキュベートが支援(審査あり)します。 ③初心者歓迎・授業料後払い 丸暗記ではなく、創りながら。初心者のための授業料後払い制度です。

0グッド

0クリップ

投稿2015/05/06 04:21

通常の「質問する」ボタンでも同じ質問をしましたが、「GsACADEMY」でも質問させていただきます。重複していたら申し訳ございません。

ボタンをクリックしたら画像を5回点滅させたいのですが、うまくいきません。
画像が消えるだけで点滅にもなっていません。

下記がコードです。

window.onload = function(){
var timer1;

btn.onclick = function(){ for(i=0;i<=4;i++){ tmstr(); } }

}

function a(){
var flga = document.getElementById("a_img").style.visibility;
if(flga == "visible")
{
document.getElementById("a_img").style.visibility = "hidden";
}else{
document.getElementById("a_img").style.visibility = "visible";
clearInterval(timer1);
}
}
function tmstr(){

timer1 = setInterval("a()",100);

}

何がいけないのでしょうか?
まだ、初心者なので初歩的なことかもしれませんがよろしくお願いします。

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

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

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

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

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

guest

回答1

0

ベストアンサー

こんにちは。

挙げられているコードには、以下のような課題があると思いました。

(1) window.onload の中の変数btnがどこで定義されているか不明

(2) for(i=0;i<=4;i++){のループによって、tmstr()を5回呼んでいるが、
setInterval() は1回呼べばOK

(3) よって、希望の回数の点滅が完了したという判定を、別に追加する必要がある。

(4) 希望の回数だけ点滅させたら点滅を終了させるための変数timer1が、window.onload の
ローカル変数となっており、tmstr()の中の timer1 は同じものを指していない。

(5) 5回点滅させたいのなら、a()のvisibilityの入れ替えは、10回行われる必要がある。

これらを解決したものを以下に挙げます。(画像はW3Cのロゴです。)

lang

1<!DOCTYPE html> 2<html> 3<head> 4<meta charset="UTF-8"> 5<title>9469</title> 6<script type="text/javascript"> 7 8var timer1; // インターバルタイマーのID 9 10var counter = 5 * 2; //点滅させたい回数×2 11 12window.onload = function(){ 13 var btn = document.getElementById("click_me_btn"); 14 btn.onclick = function(){ 15 tmstr(); 16 } 17} 18 19function a(){ 20 counter --; //カウンターを1減少して0になったら、タイマーをクリア 21 if (counter == 0) { 22 clearInterval(timer1); 23 return; 24 } 25 var flga = document.getElementById("a_img").style.visibility; 26 if(flga == "visible") 27 { 28 document.getElementById("a_img").style.visibility = "hidden"; 29 } else{ 30 document.getElementById("a_img").style.visibility = "visible"; 31 } 32} 33 34function tmstr(){ 35 timer1 = setInterval("a()", 100); 36} 37</script> 38</head> 39<body> 40<img id="a_img" src="https://www.w3.org/Icons/WWW/w3c_home_nb" /><br /> 41<input type="button" id="click_me_btn" value="click me !" /> 42</body> 43</html>

ご参考になれば幸いです。

投稿2015/05/06 05:09

編集2015/05/06 05:32
jun68ykt

総合スコア9058

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

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

HirokiNakajima

2015/05/06 11:06

ykt68様 回答ありがとうございます。 とても助かりました。 参考にさせていただきます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問