UNPKG

es-toolkit

Version:

A state-of-the-art, high-performance JavaScript utility library with a small bundle size and strong type annotations.

61 lines (58 loc) 1.8 kB
import { PropertyPath } from '../_internal/PropertyPath.js'; /** * Sets the value at the specified path of the given object. If any part of the path does not exist, it will be created. * * @template T - The type of the object. * @param {T} object - The object to modify. * @param {PropertyPath} path - The path of the property to set. * @param {any} value - The value to set. * @returns {T} - The modified object. * * @example * // Set a value in a nested object * const obj = { a: { b: { c: 3 } } }; * set(obj, 'a.b.c', 4); * console.log(obj.a.b.c); // 4 * * @example * // Set a value in an array * const arr = [1, 2, 3]; * set(arr, 1, 4); * console.log(arr[1]); // 4 * * @example * // Create non-existent path and set value * const obj = {}; * set(obj, 'a.b.c', 4); * console.log(obj); // { a: { b: { c: 4 } } } */ declare function set<T extends object>(object: T, path: PropertyPath, value: any): T; /** * Sets the value at the specified path of the given object. If any part of the path does not exist, it will be created. * * @template R - The return type. * @param {object} object - The object to modify. * @param {PropertyPath} path - The path of the property to set. * @param {any} value - The value to set. * @returns {R} - The modified object. * * @example * // Set a value in a nested object * const obj = { a: { b: { c: 3 } } }; * set(obj, 'a.b.c', 4); * console.log(obj.a.b.c); // 4 * * @example * // Set a value in an array * const arr = [1, 2, 3]; * set(arr, 1, 4); * console.log(arr[1]); // 4 * * @example * // Create non-existent path and set value * const obj = {}; * set(obj, 'a.b.c', 4); * console.log(obj); // { a: { b: { c: 4 } } } */ declare function set<R>(object: object, path: PropertyPath, value: any): R; export { set };