es-toolkit
Version:
A state-of-the-art, high-performance JavaScript utility library with a small bundle size and strong type annotations.
46 lines (43 loc) • 1.76 kB
TypeScript
import { Many } from '../_internal/Many.js';
/**
* Creates a new object with specified keys omitted.
*
* @template T - The type of object.
* @template K - The type of keys to omit.
* @param {T | null | undefined} object - The object to omit keys from.
* @param {...K} paths - The keys to be omitted from the object.
* @returns {Pick<T, Exclude<keyof T, K[number]>>} A new object with the specified keys omitted.
*
* @example
* omit({ a: 1, b: 2, c: 3 }, 'a', 'c');
* // => { b: 2 }
*/
declare function omit<T extends object, K extends PropertyKey[]>(object: T | null | undefined, ...paths: K): Pick<T, Exclude<keyof T, K[number]>>;
/**
* Creates a new object with specified keys omitted.
*
* @template T - The type of object.
* @template K - The type of keys to omit.
* @param {T | null | undefined} object - The object to omit keys from.
* @param {...Array<Many<K>>} paths - The keys to be omitted from the object.
* @returns {Omit<T, K>} A new object with the specified keys omitted.
*
* @example
* omit({ a: 1, b: 2, c: 3 }, 'a', ['b', 'c']);
* // => {}
*/
declare function omit<T extends object, K extends keyof T>(object: T | null | undefined, ...paths: Array<Many<K>>): Omit<T, K>;
/**
* Creates a new object with specified keys omitted.
*
* @template T - The type of object.
* @param {T | null | undefined} object - The object to omit keys from.
* @param {...Array<Many<PropertyKey>>} paths - The keys to be omitted from the object.
* @returns {Partial<T>} A new object with the specified keys omitted.
*
* @example
* omit({ a: 1, b: 2, c: 3 }, 'a', 'b');
* // => { c: 3 }
*/
declare function omit<T extends object>(object: T | null | undefined, ...paths: Array<Many<PropertyKey>>): Partial<T>;
export { omit };