Baseline Widely available
颿°ã®ããã©ã«ã弿°ã¯ã颿°ã«å¤ã渡ãããªãå ´åã undefined
ãæ¸¡ãããå ´åã«ãããã©ã«ãå¤ã§åæåãããå½¢å¼ä¸ã®å¼æ°ãæå®ãããã¨ãã§ãã¾ãã
function multiply(a, b = 1) {
return a * b;
}
console.log(multiply(5, 2));
// Expected output: 10
console.log(multiply(5));
// Expected output: 5
æ§æ
function fnName(param1 = defaultValue1, ..., paramN = defaultValueN) { /* ... */ }
解説
JavaScript ã§ã¯ã颿°ã®å¼æ°ã¯ãæå®ããªããã° undefined
ã«ãªãã¾ããããããå¥ãªæ¢å®å¤ãè¨å®ããã¨æç¨ãªå ´åãããããã¾ãããã®ãããªå ´åã«ãããã©ã«ã弿°ãå½¹ç«ã¡ã¾ãã
以åã¯ãæ¢å®å¤ãè¨å®ããããã®ä¸è¬çãªæ¹æ³ã¯ã颿°ã®æ¬ä½ã§å¼æ°ã®å¤ãæ¤æ»ããundefined
ã§ãã£ãå ´åã«å¤ã代å
¥ãããã¨ã§ããã
次ã®ä¾ã§ã¯ãb
ã®å¤ãæå®ããã« multiply
ãå¼ã³åºããå ´åãa
* b
ãè©ä¾¡ããã¨ãã« b
ã®å¤ã undefined
ã¨ãªããmultiply
㯠NaN
ãè¿ãã¾ãã
function multiply(a, b) {
return a * b;
}
multiply(5, 2); // 10
multiply(5); // NaN !
ãããªããã¨ãé²ãããã«ã¯ã 2 è¡ç®ã§ä½¿ããã¦ããããã«ãmultiply
ã 1 ã¤ã ãã®å¼æ°ã§å¼ã³åºãããå ´åã« b
ã 1
ã«è¨å®ãã¾ãã
function multiply(a, b) {
b = typeof b !== "undefined" ? b : 1;
return a * b;
}
multiply(5, 2); // 10
multiply(5); // 5
ES2015 ã®ããã©ã«ã弿°ãç¨ããã¨ã颿°æ¬ä½å
ã®ãã§ãã¯ã¯ãã¯ãå¿
è¦ãªããªãã¾ãã颿°ã®å
é ã§ 1
ã b
ã®æ¢å®å¤ã¨ãã¦è¨å®ããã ãã§ãã
function multiply(a, b = 1) {
return a * b;
}
multiply(5, 2); // 10
multiply(5); // 5
multiply(5, undefined); // 5
ä¾ 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:
a;
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;
default:
}
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, "=^_^="]
ã¹ã³ã¼ãã®å½±é¿
ããã©ã«ã弿°ã 1 ã¤ä»¥ä¸å®ç¾©ãããå ´åã弿°ãªã¹ãå ã®èå¥åã®ã¿ã«å¯¾ãã第äºã®ã¹ã³ã¼ã (Environment Record) ãçæããã¾ãããã®ã¹ã³ã¼ãã¯é¢æ°æ¬ä½ã®ããã«çæãããã¹ã³ã¼ãã®è¦ªã«ãªãã¾ãã
ããªãã¡ã颿°ã®æ¬ä½ã§å®£è¨ããã颿°ã夿°ã¯ãããã©ã«ãå¤ã®å¼æ°åæååããåç
§ãããã¨ãã§ãã¾ããããããè¡ããã¨ããã¨ãå®è¡æã« ReferenceError
ã®ä¾å¤ãçºçãã¾ãã
ã¾ãã颿°ã®æ¬ä½å
ã§ var
ã使ç¨ãã¦å®£è¨ãã夿°ã¯ãåãååã®å¼æ°ããã¹ã¯ããã®ã§ãé常㮠var
宣è¨ã®éè¤ã«å¹æããªãã®ã¨ã¯ç°ãªãã¾ãã
次ã®é¢æ°ã§ã¯ãããã©ã«ã弿°ã颿°æ¬ä½ã®åã¹ã³ã¼ãã«ã¢ã¯ã»ã¹ã§ããªããããå¼ã³åºããã㨠ReferenceError
ãçºçãã¾ããT
function f(a = go()) {
// `f` ãå¼ã³åºã㨠`ReferenceError` ãçºçããã
function go() {
return ":P";
}
}
...ããã¦ãã®é¢æ°ã¯ã夿° var a
ã (弿°ãªã¹ãã«ä½æããã親ã¹ã³ã¼ãã§ã¯ãªã) 颿°æ¬ä½ã«ä½æãããã¹ã³ã¼ãã®æä¸é¨ã«ã®ã¿å·»ãä¸ãããã¦ããããã undefined
ã¨è¡¨ç¤ºããã¾ãã
function f(a, b = () => console.log(a)) {
var a = 1;
b(); // `undefined` ã¨è¡¨ç¤ºãããã©ã«ã弿°ã®å¤ã¯ç¬èªã®ã¹ã³ã¼ãã«ãããã
}
ããã©ã«ã弿°ã®å¾ã®æ¢å®å¤ãªãã®å¼æ°
弿°ã¯å·¦ããå³ã«è¨å®ãããå¾ã®å¼æ°ã«æ¢å®å¤ããªãã¦ãããã©ã«ã弿°ã䏿¸ããã¾ãã
function f(x = 1, y) {
return [x, y];
}
f(); // [1, undefined]
f(2); // [2, undefined]
æ¢å®å¤ã®ããæ§é åè§£ã®å¼æ°
æ¢å®å¤ã®ä»£å ¥ããæ§é å解表è¨ã§è¡ããã¨ãã§ãã¾ãã
ãããè¡ãä¸è¬çãªæ¹æ³ã¯ã空ã®ãªãã¸ã§ã¯ã/é
åããªãã¸ã§ã¯ã/é
åã«æ§é åè§£ãããã¨ã§ããä¾ãã°ã [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
仿§æ¸ ãã©ã¦ã¶ã¼ã®äºææ§ é¢é£æ
å ±
RetroSearch is an open source project built by @garambo | Open a GitHub Issue
Search and Browse the WWW like it's 1997 | Search results from DuckDuckGo
HTML:
3.2
| Encoding:
UTF-8
| Version:
0.7.4