🎄teratailクリスマスプレゼントキャンペーン2024🎄』開催中!

\teratail特別グッズやAmazonギフトカード最大2,000円分が当たる!/

詳細はこちら
JavaScript

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

HTML

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

Q&A

解決済

1回答

861閲覧

Javascriptの2つの関数の連携方法を教えてください

kinokino1963

総合スコア1

JavaScript

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

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

HTML

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

0グッド

0クリップ

投稿2021/03/24 01:46

前提・実現したいこと

ここに質問の内容を詳しく書いてください。
(例)PHP(CakePHP)で●●なシステムを作っています。
■■な機能を実装中に以下のエラーメッセージが発生しました。

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

JavaScript・htmlを学び始めて1ヶ月未満の初学者です。2つの関数を作って、一つ目の関数の結果(数字)を表示した後、次の関数にその数字を渡して計算させるというプログラムを書こうとしてますが、うまくいきません。基本的すぎてお恥ずかしい質問かもしれませんが、よろしくお願いします。

エラーメッセージ
最初のボタン(「問題」ボタン)のクリックで一つ目の関数を動かしてランダムな数字を作って表示し、「答え」ボタンのクリックで計算結果を出すというプログラムです。問題ボタンで数字は出せるのですが、答えボタンを押しても答えが出なくて、一つ目の関数の結果が、次の関数に渡せてないのではないようです。

該当のソースコード

HTML, JavaScript
ソースコード

<body> <script> function randamu(){ var min = 10; var max = 99; var a = Math.floor(Math.random() * (max + 1 - min)) + min; var x = parseInt(a) var elem1 = document.getElementById("target"); elem1.innerHTML=(x); } </script><br>
<button class="btn1" onclick="randamu()">問題</button><br> <div id="target"></div><br> <script> function keisan(){ var y = x*x*3.14; var elem2 = document.getElementById("answer"); elem2.innerHTML=(y); } </script> <button class="btn2" onclick="keisan()" >答え</button><br> <div id="answer"></div>
</body>

ここに問題に対して試したことを記載してください。
二つ目の関数keisanに結果「x」を入れてkeisan(x)とすると答えはNaNでした。二つ目の関数からxを表示させるとundefinedと表示されるので、最初の関数の答えが次の関数に渡せていないと思った次第です。

二つめの関数keisanを一つ目のscriptに入れても結果は同じでした。keisan関数やめて、xとyを一つの関数に入れて、問題xだけ最初に表示して、次に結果yを表示させるというやり方もあるのかもしれないと思いますが、そちらもやりかたがわかりません。

1)一つ目の関数の値を次の関数に渡す方法
2)ひとつの関数にまとめて、結果xとyを違うボタンで順次出す方法

基本的は質問で恐縮でございますが、ご教示いただけたら幸いです。

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

コードはDreamweaverで書いて、google chromeでファイルを開いて試しています。実際にはもう少し複雑なJSのscriptを別のファイルに書いて、HTML内で読み込ませようとしています。

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

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

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

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

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

guest

回答1

0

ベストアンサー

randamu()の中で宣言した変数xは同じスコープ内でしか再利用できません
keisan()内で利用するためにはrandamu()外で宣言しておくか、
引数として渡すのが妥当ですが、今の作りだと前者での対応になると思います

javascript

1var x 2function randamu(){ 3・・・ 4x = parseInt(a) 5・・・

投稿2021/03/24 01:51

yambejp

総合スコア116694

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

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

kinokino1963

2021/03/24 01:59

ありがとうございます!解決しました。初めての質問でしたが、質問してみてよかったです。今後ともよろしくお願いいたします。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.36%

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

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

質問する

関連した質問