jsで関数を定義する3つの方法

Jun 15, 2018 pm 03:59 PM
js 関数

js シリーズチュートリアル 4 - 関数、関数パラメータ

js では、関数自体はオブジェクトの一種であるため、オブジェクトの属性として、またはオブジェクトのパラメータとして定義、代入することができます。その他の機能。関数名は、関数のオブジェクト クラスへの単なる参照です。

1.関数定義

【1】関数宣言文
関数キーワードに続けてパラメータのセットと関数本体を使用します

function funcname([arg1 [,arg2 [...,argn]]]){
    statement;
}
ログイン後にコピー

【2】関数定義式

式で定義された関数、関数 名前はオプションです

var functionName = function([arg1 [,arg2 [...,argn]]]){
    statement;
}var functionName = function funcName([arg1 [,arg2 [...,argn]]]){
    statement;
}
ログイン後にコピー

匿名関数(匿名関数)は、ラムダ関数とも呼ばれ、関数キーワードの後に​​識別子がない関数です

一般的に、式で関数を定義する場合、名前は必要ありません。それらを定義するコードがよりコンパクトになります。関数定義式は、一度だけ使用される関数を定義するのに特に適しています

var tensquared = (function(x) {return x*x;}(10));   //
ログイン後にコピー

関数定義式には名前が含まれますが、関数のローカル スコープには関数オブジェクトにバインドされた名前が含まれます。実際、関数の名前は関数内のローカル変数になります

var test = function fn(){   return fn;
}console.log(test);//fn(){return fn;}console.log(test());//fn(){return fn;}console.log(test()());//fn(){return fn;}
ログイン後にコピー

個人的に理解されているように、名前付き関数式の場合、関数名は関数オブジェクトの仮パラメータに相当し、関数内でのみ使用できます。変数名は同等です 関数オブジェクトの実際のパラメータについては、関数の内部と外部の両方で使用できます

var test = function fn(){   return fn === test;
}console.log(test());//trueconsole.log(test === fn);//ReferenceError: fn is not defined
ログイン後にコピー

関数は、この属性を通じて、指定された関数で指定された名前を定義できます。この属性の値は常に以下と等しくなります。 function キーワードの後の識別子、匿名関数の name 属性は空です

//IE11-浏览器无效,均输出undefined//chrome在处理匿名函数的name属性时有问题,会显示函数表达式的名字function fn(){};
console.log(fn.name);//'fn'var fn = function(){};
console.log(fn.name);//'',在chrome浏览器中会显示'fn'var fn = function abc(){};
console.log(fn.name);//'abc'
ログイン後にコピー

[3] Function コンストラクター

Function コンストラクターは任意の数のパラメーターを受け取ります。最後のパラメーターは常に関数本体とみなされ、前のパラメーターは新しい関数のパラメーターを列挙します

var functionName = new Function(['arg1' [,'arg2' [...,'argn']]],'statement;');
ログイン後にコピー

[注] Function コンストラクターでは関数名を指定できません。匿名関数が作成されます

技術的に言えば、これは次のとおりです関数式。ただし、この構文ではコードが 2 回解析されるため、お勧めできません。 1 回目は通常の JavaScript コードを解析し、2 回目はコンストラクターに渡された文字列を解析します。これはパフォーマンスに影響します

var sum = new Function('num1','num2','return num1 + num2');//等价于var sum = function(num1,num2){
    return num1+num2;
}
ログイン後にコピー

Function() コンストラクターによって作成された関数、その関数本体のコンパイルは常にグローバル スコープで実行されます。したがって、Function() コンストラクターは、グローバル スコープで実行される eval() と似ています

var test = 0;function fn(){
    var test = 1;    return new Function('return test');}
console.log(fn()());//0
ログイン後にコピー

[注] すべての関数がコンストラクターになるわけではありません

var o = new Math.min();//Uncaught TypeError: Math.min is not a constructor
ログイン後にコピー

2. 関数宣言の順序

関数宣言、変数が最初にロードされます。 。したがって、関数の宣言が呼び出しの前か後かを気にする必要はありません。

関数を呼び出すと、最初にローカルのアクティブなオブジェクト、つまり現在の js ファイル内でクエリが実行されます。したがって、同じ関数名が 2 つの js ファイルで定義されている場合は、上向きにクエリが実行されます。 2 つの js ファイルはそれぞれの関数を内部的に呼び出し、最後に宣言された関数が他の js ファイルで呼び出されます。

3. 繰り返し

変数の繰り返しの宣言は役に立たず、同じスコープ内で以前に宣言された変数を上書きしません。ただし、関数の繰り返しの宣言は、同じ名前を持つ以前に宣言された関数または変数を上書きします。

//变量的重复声明无用var a = 1;var a;
console.log(a);//1
ログイン後にコピー
//覆盖同名变量var a;function a(){
    console.log(1);
}a();//1
ログイン後にコピー
//覆盖同名函数a();//2function a(){
    console.log(1);
}function a(){
    console.log(2);
}
ログイン後にコピー

4. 削除

関数宣言文で作成した変数は、変数宣言と同様に削除できません。

function foo(){
    console.log(1);
}delete foo;//falseconsole.log(foo());//1
ログイン後にコピー

この記事では、js で関数を定義する 3 つの方法を紹介します。その他の関連コンテンツについては、php 中国語 Web サイトを参照してください。

関連する推奨事項:

JS の「真と偽」

JS を介して衝突を判断する方法!

古典的なアルゴリズムの js 実装ソリューションをいくつか紹介します

以上がjsで関数を定義する3つの方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

golang 関数で新しい関数を動的に作成するためのヒント golang 関数で新しい関数を動的に作成するためのヒント Apr 25, 2024 pm 02:39 PM

Go 言語は、クロージャとリフレクションという 2 つの動的関数作成テクノロジを提供します。クロージャを使用すると、クロージャ スコープ内の変数にアクセスでき、リフレクションでは FuncOf 関数を使用して新しい関数を作成できます。これらのテクノロジーは、HTTP ルーターのカスタマイズ、高度にカスタマイズ可能なシステムの実装、プラグイン可能なコンポーネントの構築に役立ちます。

C++ 関数の命名におけるパラメーターの順序に関する考慮事項 C++ 関数の命名におけるパラメーターの順序に関する考慮事項 Apr 24, 2024 pm 04:21 PM

C++ 関数の名前付けでは、読みやすさを向上させ、エラーを減らし、リファクタリングを容易にするために、パラメーターの順序を考慮することが重要です。一般的なパラメータの順序規則には、アクション-オブジェクト、オブジェクト-アクション、意味論的な意味、および標準ライブラリへの準拠が含まれます。最適な順序は、関数の目的、パラメーターの種類、潜在的な混乱、および言語規約によって異なります。

Java で効率的で保守しやすい関数を記述するにはどうすればよいでしょうか? Java で効率的で保守しやすい関数を記述するにはどうすればよいでしょうか? Apr 24, 2024 am 11:33 AM

効率的で保守しやすい Java 関数を作成するための鍵は、シンプルに保つことです。意味のある名前を付けてください。特殊な状況に対処します。適切な可視性を使用してください。

Excel関数の公式の完全なコレクション Excel関数の公式の完全なコレクション May 07, 2024 pm 12:04 PM

1. SUM 関数は、列またはセルのグループ内の数値を合計するために使用されます (例: =SUM(A1:J10))。 2. AVERAGE 関数は、列またはセルのグループ内の数値の平均を計算するために使用されます (例: =AVERAGE(A1:A10))。 3. COUNT 関数。列またはセルのグループ内の数値またはテキストの数をカウントするために使用されます。例: =COUNT(A1:A10)。 4. IF 関数。指定された条件に基づいて論理的な判断を行い、結果を返すために使用されます。対応する結果。

C++関数のデフォルトパラメータと可変パラメータの長所と短所の比較 C++関数のデフォルトパラメータと可変パラメータの長所と短所の比較 Apr 21, 2024 am 10:21 AM

C++ 関数のデフォルト パラメーターの利点には、呼び出しの簡素化、可読性の向上、エラーの回避などがあります。欠点は、柔軟性が限られていることと、名前の制限があることです。可変引数パラメーターの利点には、無制限の柔軟性と動的バインディングが含まれます。欠点としては、複雑さの増大、暗黙的な型変換、デバッグの難しさなどが挙げられます。

参照型を返す C++ 関数の利点は何ですか? 参照型を返す C++ 関数の利点は何ですか? Apr 20, 2024 pm 09:12 PM

C++ で参照型を返す関数の利点は次のとおりです。 パフォーマンスの向上: 参照による受け渡しによりオブジェクトのコピーが回避され、メモリと時間が節約されます。直接変更: 呼び出し元は、返された参照オブジェクトを再割り当てせずに直接変更できます。コードの簡素化: 参照渡しによりコードが簡素化され、追加の代入操作は必要ありません。

カスタム PHP 関数と定義済み関数の違いは何ですか? カスタム PHP 関数と定義済み関数の違いは何ですか? Apr 22, 2024 pm 02:21 PM

カスタム PHP 関数と定義済み関数の違いは次のとおりです。 スコープ: カスタム関数はその定義のスコープに限定されますが、事前定義関数はスクリプト全体からアクセスできます。定義方法: カスタム関数は function キーワードを使用して定義されますが、事前定義関数は PHP カーネルによって定義されます。パラメータの受け渡し: カスタム関数はパラメータを受け取りますが、事前定義された関数はパラメータを必要としない場合があります。拡張性: カスタム関数は必要に応じて作成できますが、事前定義された関数は組み込みで変更できません。

C++ 関数例外の詳細: カスタマイズされたエラー処理 C++ 関数例外の詳細: カスタマイズされたエラー処理 May 01, 2024 pm 06:39 PM

C++ の例外処理は、特定のエラー メッセージ、コンテキスト情報を提供し、エラーの種類に基づいてカスタム アクションを実行するカスタム例外クラスを通じて強化できます。 std::Exception から継承した例外クラスを定義して、特定のエラー情報を提供します。カスタム例外をスローするには、throw キーワードを使用します。 try-catch ブロックでdynamic_castを使用して、キャッチされた例外をカスタム例外タイプに変換します。実際の場合、open_file 関数は FileNotFoundException 例外をスローします。例外をキャッチして処理すると、より具体的なエラー メッセージが表示されます。

See all articles