@personal_simple_code/immutable
v1.0.3
Published
A simple logic is used to implement an API to copy only when modifying values, which minimizes the need to copy or cache data.
Downloads
17
Maintainers
Readme
immutable
Introduction
A simple logic is used to implement an API to copy only when modifying values, which minimizes the need to copy or cache data.
Always generate new updated data without changing the original data.
Software principle
Use proxy response to update, only get and set time shallow clone operands and assign values
Create a map set to store target and its real address
Shallow clone target object is real object
Execute the callback and actually listen to the real object.
When the get is triggered, the Val and its real address are stored, which is used in the set
Shallow clone and assign the read value, and return the new proxy object
When the set is triggered, obtain the real address of the target (the value of the target cannot be assigned directly). If there is: go to step 5, if there is no: assign directly
Installation tutorial
import deepClone from "@personal_simple_code/immutable"
let obj = {
a: [1, 2, 3, 4, 5],
b: { c: [123] },
d: new Map(),
e: new Set(),
}
let a = deepClone(obj, (x) => {
x.a = [0, 0, 0]
x.a[0] = 100
x.a[1]++
x.a[0] += x.a[1] + 100
x.a.push(0)
x.d.set("a", {
a: 100,
})
x.e.add(1089)
x.e.add(x.d.get("a"))
x["f"] = {
a: x.e,
}
})
console.error(`target:`, obj)
console.error(`result:`, a)
result
target: { a: [ 1, 2, 3, 4, 5 ], b: { c: [ 123 ] }, d: Map {}, e: Set {} }
result: {
a: [ 201, 1, 0, 0 ],
b: { c: [ 123 ] },
d: Map { 'a' => { a: 100 } },
e: Set { 1089, { a: 100 } },
f: { a: Set { 1089, [Object] } }
}
Instructions for use
The current version of object container only supports array, set, map and object types
The values and assignments in the callback function are all directly copied and have no reference relationship