ããã©ã«ã弿°
Baseline
Widely available
This feature is well established and works across many devices and browser versions. Itâs been available across browsers since 2016å¹´9æ.
颿°ã®ããã©ã«ã弿°ã¯ãå¤ã渡ãããªãã£ãå ´åã undefined ãæ¸¡ãããå ´åã«ãååä»ã弿°ãæ¢å®å¤ã§åæåããããã®ãã®ã§ãã
試ãã¦ã¿ã¾ããã
function multiply(a, b = 1) {
return a * b;
}
console.log(multiply(5, 2));
// äºæ³ãããçµæ: 10
console.log(multiply(5));
// äºæ³ãããçµæ: 5
æ§æ
function fnName(param1 = defaultValue1, /* â¦, */ paramN = defaultValueN) {
// â¦
}
解説
JavaScript ã§ã¯ã颿°ã®å¼æ°ã¯ãæå®ããªããã° undefined ã«ãªãã¾ããããããå¥ãªæ¢å®å¤ãè¨å®ããã¨æç¨ãªå ´åãããããã¾ãããã®ãããªå ´åã«ãããã©ã«ã弿°ãå½¹ç«ã¡ã¾ãã
次ã®ä¾ã§ã¯ãb ã®å¤ãæå®ããã« multiply ãå¼ã³åºããå ´åãa * b ãè©ä¾¡ããã¨ãã« b ã®å¤ã undefined ã¨ãªããmultiply 㯠NaN ãè¿ãã¾ãã
function multiply(a, b) {
return a * b;
}
multiply(5, 2); // 10
multiply(5); // NaN !
以åã¯ãæ¢å®å¤ãè¨å®ããä¸è¬çãªææ³ã¨ãã¦ã颿°æ¬ä½å
ã§å¼æ°ã®å¤ãæ¤æ»ãã undefined ã®å ´åã«å¤ã代å
¥ããæ¹æ³ãç¨ãããã¦ãã¾ãããæ¬¡ã®ä¾ã§ã¯ã multiply ã弿° 1 ã¤ã ãã§å¼ã³åºãããå ´åã b 㯠1 ã«è¨å®ããã¾ãã
function multiply(a, b) {
b = typeof b !== "undefined" ? b : 1;
return a * b;
}
multiply(5, 2); // 10
multiply(5); // 5
ããã©ã«ã弿°ãç¨ããã¨ã颿°æ¬ä½å
ã®ãã§ãã¯ãå¿
è¦ãªããªãã¾ãã颿°ã®å
é ã§ 1 ã b ã®æ¢å®å¤ã¨ãã¦è¨å®ããã ãã§ãã
function multiply(a, b = 1) {
return a * b;
}
multiply(5, 2); // 10
multiply(5); // 5
multiply(5, undefined); // 5
弿°ã¯å·¦ããå³ã®é åºã§è¨å®ãããæ¢å®å¤ã®ãªãå¾ç¶ã®å¼æ°ãåå¨ããå ´åã§ããæ¢å®å¤ã䏿¸ããã¾ãã
function f(x = 1, y) {
return [x, y];
}
f(); // [1, undefined]
f(2); // [2, undefined]
ã¡ã¢:
æåã®ããã©ã«ã弿°ã¨ãå¾ã«ç¶ããã¹ã¦ã®å¼æ°ã¯ã颿°ã®lengthã«ã¯å½±é¿ãã¾ããã
ããã©ã«ã弿°ã®åæååã¯ã颿°æ¬ä½ç¨ã«ä½æãããã¹ã³ã¼ãã®è¦ªã¨ãªããç¬èªã®ã¹ã³ã¼ãå ã«åå¨ãã¾ãã
ããã¯ãå¾ç¶ã®å¼æ°ã®åæååã«ããã¦ãå
è¡ãã弿°ãåç
§ã§ããã¨ãããã¨ã§ãããã ãã颿°æ¬ä½ã§å®£è¨ããã颿°ã夿°ã¯ãããã©ã«ã弿°ã®åæååããåç
§ãããã¨ã¯ã§ãã¾ãããããã試ã¿ãã¨ãå®è¡æã« ReferenceError ãçºçãã¾ããããã«ã¯é¢æ°æ¬ä½ã§ var 宣è¨ããã夿°ãå«ã¾ãã¾ãã
ä¾ãã°ã次ã®é¢æ°ã¯å¼ã³åºããã㨠ReferenceError ãçºçãã¾ããããã©ã«ã弿°ã®å¤ãã颿°æ¬ä½ã®åã¹ã³ã¼ãã®å¤æ°ã«ã¢ã¯ã»ã¹æ¨©ãæããªãããã§ãã
function f(a = go()) {
function go() {
return ":P";
}
}
f(); // ReferenceError: go is not defined
ãã®é¢æ°ã¯å¼æ°ã® a ã®å¤ãåºåãã¾ãã夿° var a ã¯é¢æ°æ¬ä½ç¨ã«ä½æãããã¹ã³ã¼ãã®å
é ã¾ã§ããå·»ãä¸ããããã弿°ãªã¹ãç¨ã«ä½æããã親ã¹ã³ã¼ãã¾ã§å·»ãä¸ããããªãããã b ããã¯ãã®å¤ãè¦ããªãããã§ãã
function f(a, b = () => console.log(a)) {
var a = 1;
b();
}
f(); // undefined
f(5); // 5
ããã©ã«ã弿°ã¯ä»»æã®å¼ã使ç¨ã§ãã¾ãããããã©ã«ãå¼ã®è©ä¾¡ã䏿忢ããã await ã yield ã¯ä½¿ç¨ã§ãã¾ããã弿°ã¯åæçã«åæåããªããã°ãªãã¾ããã
async function f(a = await Promise.resolve(1)) {
return a;
}
ã¡ã¢:
ããã©ã«ã弿°ã¯é¢æ°ãå®ç¾©ãããæã§ã¯ãªãå¼ã³åºãããæã«è©ä¾¡ããããããawait ããã³ yield æ¼ç®åã®æå¹æ§ã¯ããã®é¢æ°èªä½ã«ä¾åããå¨å²ã®é¢æ°ã«ã¯ä¾åãã¾ãããä¾ãã°ãç¾å¨ã®é¢æ°ã async ã§ãªãå ´åãawait ã¯èå¥åã¨ãã¦æ§æè§£æãããé常㮠èå¥åã®æ§æè¦å ã«å¾ãã¾ããããã¯ããã®é¢æ°ã async 颿°å
ã«å
¥ãåã§ããå ´åã§ãåæ§ã§ãã
ä¾
>undefined ã¨ãã®ä»ã®å½å¤ã渡ããå ´å
ãã®ä¾ã® 2 çªç®ã®å¼ã³åºãã§ã¯ã第 1 弿°ã§æç¤ºçã« (null ããã®ä»ã®å½å¤ã§ã¯ãªã) undefined ãè¨å®ãã¦ãã¦ããnum 弿°ã®å¤ã¯æ¢å®å¤ã®ã¾ã¾ã«ãªãã¾ãã
function test(num = 1) {
console.log(typeof num);
}
test(); // 'number' (num 㯠1 ã«è¨å®)
test(undefined); // 'number' (ãã¡ãã num 㯠1 ã«è¨å®)
// ä»ã®å½å¤ã§ã®æ¤æ»
test(""); // 'string' (num 㯠'' ã«è¨å®)
test(null); // 'object' (num 㯠null ã«è¨å®)
å¼ã³åºãæã®è©ä¾¡
ããã©ã«ã弿°ã¯å¼ã³åºãæã«è©ä¾¡ãããã®ã§ãï¼ä¾ãã°ï¼ Python ã¨ã¯ç°ãªãã颿°ãå¼ã³åºãããåº¦ã«æ°ãããªãã¸ã§ã¯ããçæããã¾ãã
function append(value, array = []) {
array.push(value);
return array;
}
append(1); // [1]
append(2); // [1, 2] ã§ã¯ãªã [2]
ããã¯ã颿°ã¨å¤æ°ã«ãé©ç¨ããã¾ãã
function callSomething(thing = something()) {
return thing;
}
let numberOfTimesCalled = 0;
function something() {
numberOfTimesCalled += 1;
return numberOfTimesCalled;
}
callSomething(); // 1
callSomething(); // 2
åã®å¼æ°ãå¾ã®ããã©ã«ã弿°ã§å©ç¨å¯è½
åã« (å·¦å´ã§) å®ç¾©ããã弿°ã¯ããã®å¾ã®ããã©ã«ã弿°ã§å©ç¨ãããã¨ãã§ãã¾ãã
function greet(name, greeting, message = `${greeting} ${name}`) {
return [name, greeting, message];
}
greet("David", "Hi"); // ["David", "Hi", "Hi David"]
greet("David", "Hi", "Happy Birthday!"); // ["David", "Hi", "Happy Birthday!"]
ãã®æ©è½ã¯ãã®ãããã¤ãã®æ¥µç«¯ãªä¾ãæ±ããã¢ã«è¿ãããããã¾ããã
function go() {
return ":P";
}
function withDefaults(
a,
b = 5,
c = b,
d = go(),
e = this,
f = arguments,
g = this.value,
) {
return [a, b, c, d, e, f, g];
}
function withoutDefaults(a, b, c, d, e, f, g) {
switch (arguments.length) {
case 0:
case 1:
b = 5;
case 2:
c = b;
case 3:
d = go();
case 4:
e = this;
case 5:
f = arguments;
case 6:
g = this.value;
}
return [a, b, c, d, e, f, g];
}
withDefaults.call({ value: "=^_^=" });
// [undefined, 5, 5, ":P", {value:"=^_^="}, arguments, "=^_^="]
withoutDefaults.call({ value: "=^_^=" });
// [undefined, 5, 5, ":P", {value:"=^_^="}, arguments, "=^_^="]
æ¢å®å¤ã®ããæ§é åè§£ã®å¼æ°
æ¢å®å¤ã®ä»£å ¥ããæ§é åè§£æ§æã§è¡ããã¨ãã§ãã¾ãã
ãããè¡ãä¸è¬çãªæ¹æ³ã¯ã空ã®ãªãã¸ã§ã¯ã/é
åããªãã¸ã§ã¯ã/é
åã«æ§é åè§£ãããã¨ã§ããä¾ãã°ã [x = 1, y = 2] = [] ã¨ãã¾ãã
ãã®ããã«ãããã¨ã§ã空ã®é
å/ãªãã¸ã§ã¯ãã颿°ã«æ¸¡ãã¦ãããããããè¨å®ããå¤ãä¿æãããã¨ãã§ãã¾ãã
function preFilledArray([x = 1, y = 2] = []) {
return x + y;
}
preFilledArray(); // 3
preFilledArray([]); // 3
preFilledArray([2]); // 4
preFilledArray([2, 3]); // 5
// ãªãã¸ã§ã¯ãã§ãåæ§ã«åä½ãã¾ãã
function preFilledObject({ z = 3 } = {}) {
return z;
}
preFilledObject(); // 3
preFilledObject({}); // 3
preFilledObject({ z: 2 }); // 2
仿§æ¸
| Specification |
|---|
| ECMAScript® 2027 Language Specification> # sec-function-definitions> |