Baseline Widely available
æ®ä½å¼æ°æ§æã«ããã颿°ãä¸å®æ°ã®å¼æ°ãé åã¨ãã¦åãå ¥ãããã¨ãã§ããå¯å¤é·å¼æ°é¢æ°ã JavaScript ã§è¡¨ããã¨ãã§ãã¾ãã
試ãã¦ã¿ã¾ãããfunction sum(...theArgs) {
let total = 0;
for (const arg of theArgs) {
total += arg;
}
return total;
}
console.log(sum(1, 2, 3));
// Expected output: 6
console.log(sum(1, 2, 3, 4));
// Expected output: 10
æ§æ
function f(a, b, ...theArgs) {
// ...
}
解説
颿°å®ç¾©ã®æå¾ã®å¼æ°ã« "...
" ï¼3 ã¤ã® U+002E FULL STOP æåï¼ã®æ¥é è¾ãä»ããã¨ãï¼ã¦ã¼ã¶ã¼ãæä¾ããï¼ãã®ä½ç½®ã«ããæ®ãã®å¼æ°ãæ¨æºã® JavaScript ã®é
åã®ä¸ã«å
¥ãããã¨ãã§ãã¾ãã æå¾ã®å¼æ°ã®ã¿ããæ®ä½å¼æ°ãã«ãªããã¨ãã§ãã¾ãã
function myFun(a, b, ...manyMoreArgs) {
console.log("a", a);
console.log("b", b);
console.log("manyMoreArgs", manyMoreArgs);
}
myFun("one", "two", "three", "four", "five", "six");
// ã³ã³ã½ã¼ã«åºå:
// a, one
// b, two
// manyMoreArgs, ["three", "four", "five", "six"]
ã¯ã¤ãã¯ãªãã¡ã¬ã³ã¹
颿°å®ç¾©ã«ã¯ã ...
restParam ã 1 ã¤ã ãå
¥ãããã¨ãã§ãã¾ãã
foo(...one, ...wrong, ...wrong);
æ®ä½å¼æ°ã¯ã颿°å®ç¾©ã®æå¾ã®å¼æ°ã§ãªããã°ãªãã¾ããã
foo(...wrong, arg2, arg3);
foo(arg1, arg2, ...correct);
æ®ä½å¼æ°ã¨ arguments
ãªãã¸ã§ã¯ãã¨ã®éã
æ®ä½å¼æ°ã¨ arguments
ãªãã¸ã§ã¯ãã®éã«ã¯ã主㫠3 ã¤ã®éããããã¾ãã
arguments
ãªãã¸ã§ã¯ãã¯å®éã®é
åã§ã¯ããã¾ããã䏿¹ãæ®ä½å¼æ°ã¯ Array
ã¤ã³ã¹ã¿ã³ã¹ã§ããã¤ã¾ããsort
, map
, forEach
, pop
ãªã©ã®ã¡ã½ãããç´æ¥é©ç¨ã§ãã¾ããarguments
ãªãã¸ã§ã¯ãã¯ãï¼callee
ããããã£ã®ããã«ï¼èªèº«ã¸ã®åºæã®è¿½å æ©è½ãæã£ã¦ãã¾ãã...restParam
ã¯ãã¹ã¦ã®è¿½å 弿°ãä¸ã¤ã®é
åã«æãããã®ã§ã ...restParam
ã®åã«å®ç¾©ãããååä»ã弿°ã¯å«ã¾ãã¾ããã䏿¹ã arguments
ãªãã¸ã§ã¯ãã¯ã ...restParam
é
åã®å¼æ°ãå«ããã¹ã¦ã®å¼æ°ãã 1 ã¤ã®é
å風ãªãã¸ã§ã¯ãã«æãããã®ãå«ãã§ãã¾ããæ®ä½å¼æ°ã¯ã弿°ã«ããå¼ãèµ·ããããå®åã³ã¼ããæ¸ããããã«å°å ¥ããã¾ããã
// æ®ä½å¼æ°ã®ç»å ´ä»¥åã¯ã"arguments" ãæ®éã®é
åã«å¤æããã«ã¯ä»¥ä¸ã®ããã«ãã¦ãã¾ããã
function f(a, b) {
let normalArray = Array.prototype.slice.call(arguments);
// -- or --
let normalArray = [].slice.call(arguments);
// -- or --
let normalArray = Array.from(arguments);
let first = normalArray.shift(); // OKãæåã®å¼æ°ãå¾ããã
let first = arguments.shift(); // ã¨ã©ã¼ (arguments ã¯é常ã®é
åã§ã¯ãªã)
}
// æ®ä½å¼æ°ã使ã£ã¦ãµã¤ãã®é
åã¸ã®ã¢ã¯ã»ã¹ãå¾ãããããã«ãªãã¾ãã
function f(...args) {
let normalArray = args;
let first = normalArray.shift(); // OKãæåã®å¼æ°ãå¾ããã
}
ä¾ æ®ä½å¼æ°ã®ä½¿ç¨
ãã®ä¾ã§ã¯ãæåã®å¼æ°ã a
ã«ã 2 çªç®ã®å¼æ°ã b
ã«å²ãå½ã¦ããã¾ãã®ã§ããããã®ååä»ã弿°ã¯ãµã¤ãéã使ããã¾ãã
ãããã 3 çªç®ã®å¼æ°ãmanyMoreArgs
ã¯ã 3 çªç®ã 4 çªç®ã 5 çªç®ã 6 çªç®ãï½ n çªç® â ã¦ã¼ã¶ã¼ãå
¥ããã ãã®æ°ã®å¼æ°ãæã¤é
åã«ãªãã¾ãã
function myFun(a, b, ...manyMoreArgs) {
console.log("a", a);
console.log("b", b);
console.log("manyMoreArgs", manyMoreArgs);
}
myFun("one", "two", "three", "four", "five", "six");
// a, "one"
// b, "two"
// manyMoreArgs, ["three", "four", "five", "six"] <-- é
åã§ãããã¨ã«æ³¨æ
以ä¸ãå¤ã1ã¤ãããªãã¦ããæå¾ã®å¼æ°ã¯é åã«å ¥ããããã
// ä¸è¨ã®ä¾ã¨åã颿°å®ç¾©ã使ç¨
myFun("one", "two", "three");
// a, "one"
// b, "two"
// manyMoreArgs, ["three"] <-- å¤ã 1 ã¤ã ãã§ãé
åã§ãããã¨ã«æ³¨æ
以ä¸ã®ä¾ã§ã¯ã 3 çªç®ã®å¼æ°ãæä¾ããã¦ãã¾ãããã manyMoreArgs
ã¯é
åã®ã¾ã¾ã§ãï¼ãã ã空ã®ãã®ã§ãï¼ã
// ä¸è¨ã®ä¾ã¨åã颿°å®ç¾©ã使ç¨
myFun("one", "two");
// a, "one"
// b, "two"
// manyMoreArgs, [] <-- ãã¯ããããé
å
弿°ã®é·ã
theArgs
ã¯é
åãªã®ã§ã length
ããããã£ã使ç¨ãã¦è¦ç´ æ°ãåå¾ãããã¨ãã§ãã¾ãã
function fun1(...theArgs) {
console.log(theArgs.length);
}
fun1(); // 0
fun1(5); // 1
fun1(5, 6, 7); // 3
é常ã®å¼æ°ã¨æ®ä½å¼æ°
次ã®ä¾ã§ã¯ãæ®ä½å¼æ°ã使ç¨ã㦠2 çªç®ã®å¼æ°ããæå¾ã®å¼æ°ã¾ã§ãé åã«éãã¦ãã¾ãããããããããããæåã®å¼æ°ã¨ä¹ç®ãããã®é åãè¿ãã¾ãã
function multiply(multiplier, ...theArgs) {
return theArgs.map((element) => {
return multiplier * element;
});
}
let arr = multiply(2, 15, 25, 42);
console.log(arr); // [30, 50, 84]
æ®ä½å¼æ°ã¯å®éã®é
åã arguments ãªãã¸ã§ã¯ãã¯ããã§ã¯ãªã
Array
ã®ã¡ã½ãããæ®ä½å¼æ°ã§å©ç¨ãããã¨ãã§ãã¾ããã arguments
ãªãã¸ã§ã¯ãã§ã¯å©ç¨ã§ãã¾ããã
function sortRestArgs(...theArgs) {
let sortedArgs = theArgs.sort();
return sortedArgs;
}
console.log(sortRestArgs(5, 3, 7, 1)); // 1, 3, 5, 7
function sortArguments() {
let sortedArgs = arguments.sort();
return sortedArgs; // ããã¯å®è¡ãããªã
}
console.log(sortArguments(5, 3, 7, 1));
// TypeError ãçºç (arguments.sort ã¯é¢æ°ã§ã¯ãªã)
Array
ã®ã¡ã½ããã arguments
ãªãã¸ã§ã¯ãã§ä½¿ç¨ããã«ã¯ãã¾ããªãã¸ã§ã¯ããå®éã®é
åã«å¤æããå¿
è¦ãããã¾ãã
function sortArguments() {
let args = Array.from(arguments);
let sortedArgs = args.sort();
return sortedArgs;
}
console.log(sortArguments(5, 3, 7, 1)); // 1, 3, 5, 7
仿§æ¸ ãã©ã¦ã¶ã¼ã®äºææ§ é¢é£æ
å ±
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