Skip to main content
Module

x/ramda/source/assoc.js

:ram: Practical functional Javascript
Latest
File
import _curry3 from './internal/_curry3.js';import assocPath from './assocPath.js';
/** * Makes a shallow clone of an object, setting or overriding the specified * property with the given value. Note that this copies and flattens prototype * properties onto the new object as well. All non-primitive properties are * copied by reference. * * @func * @memberOf R * @since v0.8.0 * @category Object * @typedefn Idx = String | Int * @sig Idx -> a -> {k: v} -> {k: v} * @param {String|Number} prop The property name to set * @param {*} val The new value * @param {Object} obj The object to clone * @return {Object} A new object equivalent to the original except for the changed property. * @see R.dissoc, R.pick * @example * * R.assoc('c', 3, {a: 1, b: 2}); //=> {a: 1, b: 2, c: 3} */var assoc = _curry3(function assoc(prop, val, obj) { return assocPath([prop], val, obj); });export default assoc;