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

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

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

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

Q&A

解決済

3回答

330閲覧

javascriptの返り値について

退会済みユーザー

退会済みユーザー

総合スコア0

JavaScript

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

0グッド

0クリップ

投稿2018/10/24 13:34

function attack(item) { if (item === "手裏剣") { return "相手に大ダメージを与えた!"; } return "相手にダメージを与えた!"; } console.log(attack("手裏剣"));

returnが2つあるのですが、一つ目のreturnで呼び出し元に返る気がするのですが、
どうして↑のようなコードになるのか、理屈を教えて頂けないでしょうか。

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

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

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

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

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

guest

回答3

0

ベストアンサー

ちょっと別の書き方をすると

function attack(item) { if (item === "手裏剣") { return "相手に大ダメージを与えた!"; } else { return "相手にダメージを与えた!"; } }

リターンが気になるなら

function attack(item) { var x = "相手にダメージを与えた!"; if (item === "手裏剣") { x = "相手に大ダメージを与えた!"; } return x; }

コードを減らすなら

function attack(item) { return (item === "手裏剣") ? "相手に大ダメージを与えた!" : "相手にダメージを与えた!"; }

拡張性を考えるなら

function attack(item) { var msg = ["相手にダメージを与えた!","相手に大ダメージを与えた!"] var i; switch (item) { case "手裏剣": i = 1; break; default: i = 0; } return msg[i]; }

とまあ、同じ機能を実現するにもいろんな書き方がありまして。
で、今回の質問で提示されたコードは、条件によって
return は一回しか実行されないことを見極めましょう。

投稿2018/10/24 14:05

takasima20

総合スコア7458

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

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

退会済みユーザー

退会済みユーザー

2018/10/24 14:11

色々な書き方があるのですね・・。
guest

0

item が "手裏剣"じゃない場合を考えればわかると思います。

投稿2018/10/24 13:36

kaba

総合スコア314

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

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

0

JavaScript

1// これだとif条件に当てはまるので上のreturnで呼び出し元に戻る 2console.log(attack("手裏剣")); 3 4 5// これだとif条件に当てはまらないので下のreturnで呼び出し元に戻る 6console.log(attack("hoge"));

条件一致したときとしないときで返したい値を変えたいからやっているのではと思います。

投稿2018/10/24 13:36

rururu3

総合スコア5545

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

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

退会済みユーザー

退会済みユーザー

2018/10/24 13:57

ありがとうございます。else { return "相手にダメージを与えた!";}というふうにしなくてよいのですね
rururu3

2018/10/24 14:10

elseでやってもいいですが、最後で値を必ず返すとわかりやすいからこういう書き方のほうが良かったはず &ガード節・・・っていう手法だったはず
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.48%

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

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

質問する

関連した質問