guardObjectKeysIn()
guardObjectKeysIn()
guardObjectKeysIn()
Guards the value to be an object
of a generic type variable Obj
with specified keys in it(or its prototype chain).
Generic type variables
Obj
extends
object
Obj
extends
object
A generic type variable Obj
constrained by object
indicates captured object
type of the given value
via the return type and the value
parameter of the provided callback
function ResultCallback
type.
Key
extends keyof
Obj
Key
extends keyof
Obj
A generic type variable Key
constrained by the keyof Obj
, by default of value captured from the supplied keys
indicates the specific property name of Obj
.
Payload
extends
object
=
object
Payload
extends
object
=
object
The Payload
generic type variable constrained by object
indicates the type of optional parameter payload
of the supplied callback
function and payload
optional parameter of the guardObjectKeysIn()
function from which it captures its value.
Parameters
value: Obj
value: Obj
An object
of a generic type variable Obj
, by default of the type captured from itself that contains(or its prototype chain) the given keys
to guard.
keys: Key[]
keys: Key[]
An Array
of property keys to check whether the given value
contains(or its prototype chain).
callback?: ResultCallback<Obj, { keys: typeof keys } & Payload>
callback?: ResultCallback<Obj, { keys: typeof keys } & Payload>
The optional callback function
of ResultCallback
type with parameters, the value
that has been checked, the result
of this check, and payload
of generic type variable Payload
with optional properties from the provided payload
, to handle them before the result
return. By default, it uses resultCallback()
function.
payload?: Payload
payload?: Payload
An optional object
of the generic type variable Payload
is assigned to the payload
of the given callback
function.
Return type
value is
Obj
value is
Obj
The return type is a boolean
as the result of its statement indicating the value
is an object
of a generic type variable Obj
, by default of type captured from the supplied value
.
Returns
The return value is a boolean
indicating whether the value
is an object
with specified keys
in it(or its prototype chain).
Example usage
Last updated