JavaScript で関数を作成する方法は何通りあるかご存知ですか?次の記事では、JavaScript で関数を定義するさまざまな方法を紹介します。一定の参考値があるので、困っている友達が参考になれば幸いです。
#1. 宣言関数 #
function sum(a, b) { return a + b; }
#2. 式関数 #// 可以命名:
(function sum(a, b) { return a + b; });
// 也可匿名 (AVOID):
(function(a, b) { return a + b; });
// 也能分配给变量:
const sum = function sum(a, b) { return a + b; })
3. アロー関数// 一般形式:
(a, b) => { return a + b };
// 单参数,一行返回:
name => name.split(' ')
// 多参数,一行返回:
(a, b) => a + b
// 单参数,带函数体
name => { return name.split(' '); }
function *sum(a, b) { yield a + b; }
async function sum(a, b) { return await a + b; }
new Function(‘a’, ‘b’, ‘return a + b;’);
##// 默认导出
export default function(a, b) { return a + b; };
// 命名导出
export function sum(a, b) { return a + b; };
// 一般形式: const object = { sum: function(a, b) { return a + b; }, }; // 简写: const object = { sum(a, b) { return a + b; }, };
const functionName = "sum"; const object = { [functionName]: function(a, b) { return a + b; }, };
#// 一般形式:
const object = {
get answer { return 42; },
set answer(value) { /* 一些操作value的代码 */ },
};
// 使用 defineProperty
const obj = {};
Object.defineProperty(obj, "answer", {
get() { return 42; },
set(value) { /* 一些操作value的代码 */ },
});
const functionName = "answer";
const object = {
get [functionName]() { return 42; },
set [functionName](value) { /* 一些操作value的代码 */ },
};
class Compute {
// 一般形式:
sum(a, b) { return a + b; }
}
class Compute {
// 静态:
static sum(a, b) { return a + b; };
}
class Compute {
// 一般形式:
sum = function (a, b) { return a + b; };
}class Compute {
// 静态:
static sum = function(a, b) { return a + b; };
}
class Compute {
// 一般形式:
#sum(a, b) {
return a + b;
} // 静态:
static #sum(a, b) {
return a + b;
}
}
他の方法をご存知ですか? メッセージを残して教えてください。 関連する無料学習の推奨事項:
js ビデオ チュートリアル以上がJS で関数を定義するいくつかの方法の詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。