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

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

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

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

HTML

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

Q&A

解決済

2回答

1704閲覧

javascriptのfor文について質問です。

busshi77

総合スコア12

JavaScript

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

HTML

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

0グッド

0クリップ

投稿2016/11/10 03:17

###前提・実現したいこと
現在、javascriptを使用してHTMLで出力するということをしています。
for文を使用し指定された回数分3を足すという内容をHTMLで出力するということを現在行っています。しかし、aがReferensErrorと出てしまい、計算されません。どなたかご教授お願いします。

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

Uncaught ReferenceError: a is not defined

###該当のソースコード
HTML

<p onclick = "suji10(a);", id = "idsuji">[10]</p>

java

function suji10(a){
var suji =document.getElementById("idsuji");
var a;

for(var num = 0; num < 10; ++num){
a += 3;
}
suji.innerHTML = "<p>[10]</p><p>答え: " + a + "</p>"
}

ここにご自身が実行したソースコードを書いてください

###試したこと

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

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

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

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

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

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

guest

回答2

0

<p onclick = "suji10(a);", id = "idsuji">[10]</p>

この部分でsuji10()変数aを渡していますが、これが実行される時点で初期化されていないのではありませんか?

投稿2016/11/10 03:31

KaedeKazane

総合スコア408

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

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

busshi77

2016/11/10 04:00

回答ありがとうございます!
guest

0

ベストアンサー

単純に質問内容で修正すると以下のようになります。

HTML

1<p onclick = "suji10();" id = "idsuji">[10]</p>

JavaScript

1function suji10(){ 2 var suji =document.getElementById("idsuji"); 3 var a = 0; 4 for(var num = 0; num < 10; ++num){ 5 a += 3; 6 } 7 suji.innerHTML = "<p>[10]</p><p>答え: " + a + "</p>" 8}

上記とは別に「入力した数字に指定された回数分3を足す」パターンだと

HTML

1<input type="number" id="inputNum"/> 2<p onclick = "suji10();" id = "idsuji">[10]</p>

JavaScript

1function suji10(){ 2 var suji =document.getElementById("idsuji"); 3 var a = parseInt(document.getElementById("inputNum").value); 4 for(var num = 0; num < 10; ++num){ 5 a += 3; 6 } 7 suji.innerHTML = "<p>[10]</p><p>答え: " + a + "</p>"; 8}

なんて感じで出来ます。
引数を使用していたようなのでどちらかというとこっちのほうが求められている答えになるでしょうか?
Liveweave
このあたりのサイトを使用すると簡単に動きが確認できて便利ですのでよろしければ。

投稿2016/11/10 03:28

編集2016/11/10 03:50
Alice0225

総合スコア206

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

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

busshi77

2016/11/10 03:59

迅速な対応とわかりやすい回答ありがとうございました!
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.37%

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

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

質問する

関連した質問