isObjectKeys()
isObjectKeys()
isObjectKeys()Checks if any value is an object(by using the isObject()) with its keys by using hasOwnProperty() method of Object.
const isObjectKeys = <Obj = object, Payload extends object = object>(
value: any,
keys: PropertyKey[],
callback: ResultCallback<
any,
{ keys: typeof keys } & Payload
> = resultCallback,
payload?: Payload
): value is Obj =>
callback(
isObject(value) && isArray(keys)
? keys.every((key) => ({}.hasOwnProperty.call(value, key)))
: false,
value,
{ ...payload, keys } as any
);Generic type variables
Obj=object
Obj=objectA generic type variable Obj indicates the type of the given value parameter via the return type value is Obj, by default object.
Payloadextendsobject=object
Payloadextendsobject=objectThe 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 isObjectKeys() function from which it captures its value.
Parameters
value: any
value: anyThe value of any type to check against an object that contains its keys from given keys.
keys: PropertyKey[]
keys: PropertyKey[]An Array of property keys to check if a given value contains.
callback: ResultCallback<any, { keys: typeof keys } & Payload>
callback: ResultCallback<any, { keys: typeof keys } & Payload>A 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?: PayloadAn 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 ObjThe return type is a boolean as the result of its statement indicating the value is a generic type variable Obj by default equal to the object.
Returns
The return value is a boolean indicating whether the provided value is an object with its keys.
Example usage
// Example usage.
import { isObjectKeys } from '@angular-package/type';
class Person {
firstName = 'name';
surname = 'surname';
age = 27;
city = 'New York';
sex = 'Male';
get getAge(): number {
return this.age;
}
}
const person = new Person();
// Define property.
Object.defineProperty(person, 'notEnumerable', { enumerable: false });
person.propertyIsEnumerable('notEnumerable'); // Returns `false`.
isObjectKeys(person, ['firstName']); // Returns `true` as `value is object`.
isObjectKeys(person, ['firstName', 'surname']); // Returns `true` as `value is object`.
isObjectKeys(person, ['firstName', 'no property']); // Returns `false` as `value is object`.
// Getter.
isObjectKeys(person, ['getAge']); // Returns `false` as `value is object`.
// not enumerable.
isObjectKeys(person, ['notEnumerable']); // Returns `true` as `value is object`.
/*
Returns [
"firstName",
"surname",
"age",
"city",
"sex"
]
*/
Object.keys(person);Last updated
Was this helpful?