Sometimes I want to have a named argument but also destructure from it in a single definition. It happens most often when I'm using the keyword-args style of coding that has become relatively common. I'll end up writing something like this:
let setWithKeywordArgs = (
id = 0,
props = {},
) => {
const {
disable = false,
name = 'Submit',
} = props;
// ...
}
The problem I have with this is that JS nearly invented an awesome self-documenting capability where a function's arguments read without its body form a declarative description of what the function considers its arguments.
Imagine I were able to write somethingthat read more like this instead:
let setWithKeywordArgs = (
id = 0,
props {
disable = false,
name = 'Submit',
} = {},
) => {
return new Boolean;
}
Now it would be the world's easiest project to strip this down to the self-documenting keyword-args-supporting signature:
setWithKeywordArgs = (
id = 0,
props {
disable = false,
name = 'Submit',
} = {},
) => Boolean
Of course it is already possible to do this by omitting the name of the keyword-args-like argument, but this is not without significant drawbacks. The parameter name is really gone, and will be unavailable for code intelligence or to assist in the creation of documentation. Furthermore the implementation of the method will be unable to forward its complete keyword arguments to another function.
Does anyone have any thoughts on why this hasn't happened already?
What syntaxes are theoretically plausible?