I have this class
export class dialogConfig {
title: String;
message?: String;
okText?: String;
withDecline?: false;
width?: Number;
height?: Number;
}
and I have this function
openDialog(config:dialogConfig){
...
});
I wanna call the function like this
openDialog({
title: 'viola'
}
The rest of the parameters that are not specified, I wanna set default values. How can I achieve this.
Things that should probably change about this question:
dialogConfig
should be DialogConfig
, as it is conventional in TypeScript for named object types to start with an uppercase letter. Initial-lowercase identifiers usually signify variable names or possibly primitive types.
I suspect you should be using an interface
instead of a class
. The value {title: "viola"}
is not actually an instance of any such class at runtime. You can use a class
as an interface
, which is why openDialog({title: "viola"})
is not an error, but it's more straightforward to use an interface
directly. Unless you are writing new DialogConfig()
or instanceof DialogConfig
you don't need class
. And if you are writing those things you should be very careful with non-instance literals like {title: "viola"}
.
Number
should be number
and String
should be string
. It's almost always a mistake to use the uppercase versions of primitive data types.
false
should probably be boolean
, unless you're saying that withDecline
should, when specified, always be false
. That's possible, but I'm confused about how that would work with the intended use case of specifying default values when left out. If you ever want withDecline
to be true
, then you want boolean
.
That gives us this:
interface DialogConfig {
title: string;
message?: string;
okText?: string;
withDecline?: boolean;
width?: number;
height?: number;
}
That being said, here's how I'd assign default values:
const defaultValues = {
message: "",
okText: "",
withDecline: false,
width: 0,
height: 0
}
function openDialog(config: DialogConfig) {
const filledInConfig: Required<DialogConfig> = { ...defaultValues, ...config };
console.log(JSON.stringify(filledInConfig));
};
Here I'm using an object called defaultValues
, and using object spread to create a new value with all the properties from defaultValues
which is then overwritten with all the properties of config
. Assuming that config
doesn't have any explicitly included undefined
properties, this will result in a filledInConfig
value of type Required<DialogConfig>
, the same as DialogConfig
but with all the properties required instead of having some of them as optional.
If you don't want to use object spread there's also Object.assign()
:
const filledInConfig: Required<DialogConfig> = Object.assign({}, defaultValues, config);
Either way will result in the desired result:
openDialog({
title: 'viola'
});
// {"message":"","okText":"","withDecline":false,"width":0,"height":0,"title":"viola"}
Okay, hope that helps; good luck!
Playground link to code
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With