From 33058f2b292b3a581333bdfb21b8f671898c5060 Mon Sep 17 00:00:00 2001 From: Peter Bengtsson Date: Tue, 8 Dec 2020 14:40:17 -0500 Subject: initial commit --- .../errors/unnamed_function_statement/index.html | 115 +++++++++++++++++++++ 1 file changed, 115 insertions(+) create mode 100644 files/ja/web/javascript/reference/errors/unnamed_function_statement/index.html (limited to 'files/ja/web/javascript/reference/errors/unnamed_function_statement') diff --git a/files/ja/web/javascript/reference/errors/unnamed_function_statement/index.html b/files/ja/web/javascript/reference/errors/unnamed_function_statement/index.html new file mode 100644 index 0000000000..35abd0a3f6 --- /dev/null +++ b/files/ja/web/javascript/reference/errors/unnamed_function_statement/index.html @@ -0,0 +1,115 @@ +--- +title: 'SyntaxError: function statement requires a name' +slug: Web/JavaScript/Reference/Errors/Unnamed_function_statement +tags: + - Error + - Errors + - JavaScript + - SyntaxError +translation_of: Web/JavaScript/Reference/Errors/Unnamed_function_statement +--- +
{{jsSidebar("Errors")}}
+ +

メッセージ

+ +
SyntaxError: function statement requires a name [Firefox]
+SyntaxError: Unexpected token ( [Chrome]
+
+ +

エラータイプ

+ +

{{jsxref("SyntaxError")}}

+ +

何がうまくいかなかったのか?

+ +

コードに名前が必要な function ステートメントがあります。関数がどのように定義されているか、関数の名前を指定する必要があるかどうか、または問題の関数が関数式、{{Glossary("IIFE")}} である必要があるかどうか、 コードがこのコンテクストに正しく置かれているかどうかを確認する必要があります。

+ +

+ +

ステートメント vs 式

+ +

function ステートメント (または function 宣言) では名前が必要であり、これは動作しません:

+ +
function () {
+  return 'Hello world';
+}
+// SyntaxError: function statement requires a name
+
+ +

代わりに、function 式 (代入) を使用できます:

+ +
var greet = function() {
+  return 'Hello world';
+};
+ +

または、定義するとすぐに実行される IIFE (即時実行関数式) を定義しようとしているのかもしれません。その場合は、もう少々括弧が必要です:

+ +
(function () {
+
+})();
+ +

ラベル付けされた関数

+ +

関数 label を使用している場合、function キーワードの後に関数名を指定する必要があります。これは動作しません:

+ +
function Greeter() {
+  german: function () {
+    return "Moin";
+  }
+}
+// SyntaxError: function statement requires a name
+
+ +

たとえば、これは動作します:

+ +
function Greeter() {
+  german: function g() {
+    return "Moin";
+  }
+}
+ +

オブジェクトのメソッド

+ +

オブジェクトのメソッドを作るならば、オブジェクトを作る必要があります。その場合、function キーワードの後に名前がない次の構文は有効です。

+ +
var greeter = {
+  german: function () {
+    return "Moin";
+  }
+};
+ +

コールバック構文

+ +

コールバックを使用するときの構文もチェックします。大括弧とカンマが混同しやすいです。

+ +
promise.then(
+  function() {
+    console.log("success");
+  });
+  function() {
+    console.log("error");
+}
+// SyntaxError: function statement requires a name
+
+ +

正しくは:

+ +
promise.then(
+  function() {
+    console.log("success");
+  },
+  function() {
+    console.log("error");
+  }
+);
+
+ +

関連項目

+ + -- cgit v1.2.3-54-g00ecf