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

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

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

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

Q&A

解決済

1回答

212閲覧

functionの役割を教えてください。

amanha

総合スコア11

JavaScript

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

0グッド

1クリップ

投稿2020/06/07 05:32

最初のコード、
(function(){
'use strict';

でfunctionが出てきます。調べてみたらfunctionは定数を定義するものらしく、今のletやconstみたいなものだと出てきたのですが、なぜ()にfunctionが囲まれているのか分かりません。
このfunctionは宣言でしょうか?
また、最後のコード

btn.addEventListener('mouseup', function(){
this.className = '';
});

におけるfunctionの役割も教えていただけると幸いです。よろしくお願いします。

``JavaScript

(function(){
'use strict';

let btn = document.getElementById('btn');

btn.addEventListener('click', function(){
var n = Math.random()
if(n < 0.3){
this.textContent = '大吉'; // 30%
}else if (n < 0.45){
this.textContent = '吉'; // 15%
}else if (n < 0.60){
this.textContent = '中吉'; // 15%
}else if (n < 0.85){
this.textContent = '小吉'; // 15%
}else{
this.textContent = '凶'; // 15%
}

});
btn.addEventListener('mousedown', function(){
this.className = 'pushed';
});

btn.addEventListener('mouseup', function(){
this.className = '';
});

})();

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

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

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

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

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

kei344

2020/06/07 05:35

> functionは定数を定義するもの 調べたキーワードと、それが書いてあったページURLを記載してください。
kei344

2020/06/07 05:41

当該ページに「定数」という文字列がありません。どの部分でしょうか。
guest

回答1

0

ベストアンサー

調べてみたらfunctionは定数を定義するものらしく、

いえ、違います、「カッコの中」など、式の途中に現れるfunction関数リテラルFunctionオブジェクトを作るためのリテラル)です。

(function(){ /* 略 */ })();という形となっていますが、これは「今作った関数リテラルをその場で実行する」という、即時関数と呼ばれる形です。

最後のコードにおけるfunctionの役割

こちらも関数リテラルで、イベントハンドラとして登録する関数を作っています。

投稿2020/06/07 05:39

maisumakun

総合スコア145184

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

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

amanha

2020/06/07 05:46

教えてくださってありがとうございます。 関数リテラルというものだったんですね! 定数を宣言するものだと思っていた自分が恥ずかしいです。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.47%

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

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

質問する

関連した質問