Deprecated
This feature is no longer recommended. Though some browsers might still support it, it may have already been removed from the relevant web standards, may be in the process of being dropped, or may only be kept for compatibility purposes. Avoid using it, and update existing code if possible; see the compatibility table at the bottom of this page to guide your decision. Be aware that this feature may cease to work at any time.
The function.arguments
property refers to an an array-like object corresponding to the arguments passed to a function. Use the simple variable arguments
instead. This property is forbidden in strict model due to tail call optimization.
The syntax function.arguments
is deprecated. The recommended way to access the arguments
object available within functions is simply to refer to the variable arguments
.
In the case of recursion, i.e. if function f
appears several times on the call stack, the value of f.arguments
represents the arguments corresponding to the most recent invocation of the function.
The value of the arguments property is normally null if there is no outstanding invocation of the function in progress (that is, the function has been called but has not yet returned.
function f(n) { g(n - 1); } function g(n) { console.log('before: ' + g.arguments[0]); if (n > 0) { f(n); } console.log('after: ' + g.arguments[0]); } f(2); console.log('returned: ' + g.arguments); // Output // before: 1 // before: 0 // after: 0 // after: 1 // returned: null
Specification | Status | Comment |
---|---|---|
ECMAScript 1st Edition (ECMA-262) | Standard | Initial definition. Implemented in JavaScript 1.0. Deprecated in favor of arguments in ES3. |
ECMAScript 5.1 (ECMA-262) The definition of 'arguments object' in that specification. | Standard |
arguments object |
ECMAScript 2015 (6th Edition, ECMA-262) The definition of 'arguments object' in that specification. | Standard |
arguments object |
ECMAScript Latest Draft (ECMA-262) The definition of 'arguments object' in that specification. | Draft |
arguments object |
Desktop | ||||||
---|---|---|---|---|---|---|
Chrome | Edge | Firefox | Internet Explorer | Opera | Safari | |
Basic support | Yes | Yes | 1 | Yes | Yes | Yes |
Mobile | |||||||
---|---|---|---|---|---|---|---|
Android webview | Chrome for Android | Edge Mobile | Firefox for Android | Opera for Android | iOS Safari | Samsung Internet | |
Basic support | Yes | Yes | Yes | 4 | Yes | Yes | Yes |
Server | |
---|---|
Node.js | |
Basic support | Yes |
© 2005–2018 Mozilla Developer Network and individual contributors.
Licensed under the Creative Commons Attribution-ShareAlike License v2.5 or later.
https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Function/arguments