Package Exports
- @igor.dvlpr/node-clone-js
- @igor.dvlpr/node-clone-js/dist/index.mjs
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@igor.dvlpr/node-clone-js) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
𧬠A lightweight JavaScript utility allowing deep copy-by-value of nested objects, arrays and arrays of objects. πͺ
npm('clone.js')
π Support further development
I work hard for every project, including this one and your support means a lot to me!
Consider buying me a coffee. β
Thank you for supporting my efforts! ππ
![]()
@igorskyflyer
π΅πΌ Usage
Install it by executing:
npm i "@igor.dvlpr/node-clone-js"
π€ΉπΌ API
Simple array copy
import { clone } from '@igor.dvlpr/node-clone-js'
const firstArray = [1, 2, 3]
const secondArray = clone(firstArray)
secondArray[0] = 5
console.log('firstArray => ', firstArray) // [1, 2, 3]
console.log('secondArray => ', secondArray) // [5, 2, 3]
Complex array (array of objects)
import { clone } from '@igor.dvlpr/node-clone-js'
const firstArray = [
{
id: '103',
name: 'Peter',
},
{
id: '214',
name: 'Eve',
},
]
const secondArray = clone(firstArray)
secondArray[0].name = 'John'
console.log('firstArray => ', firstArray)
console.log('secondArray => ', secondArray)
Simple object copy
import { clone } from '@igor.dvlpr/node-clone-js'
const firstStudent = {
id: 103,
name: 'Ben',
classes: ['Maths', 'Science', 'English language'],
}
const secondStudent = clone(firstStudent)
secondStudent.classes[0] = 'Psychology'
console.log('firstStudent => ', firstStudent)
console.log('secondStudent => ', secondStudent)
Nested object copy
import { clone } from '@igor.dvlpr/node-clone-js'
const firstStudent = {
id: 103,
name: 'Ben',
subjects: {
groupDke: {
science: 'B',
maths: 'C',
},
groupOpe: {
foo: 'bar',
},
},
}
const secondStudent = clone(firstStudent)
secondStudent.subjects.groupDke.maths = 'B'
console.log('firstStudent => ', firstStudent)
console.log('secondStudent => ', secondStudent)
Development
git clone https://github.com/igorskyflyer/npm-clone-js.git
cd npm-clone-js
npm install
Test
npm test
πͺͺ License
Licensed under the MIT license which is available here, MIT license.
𧬠Related
π§² Provides ways of properly checking if a path exists inside a given array of files/directories both on Windows and UNIX-like operating systems. πΊ
π§ Zep is a zero-dependency, efficient debounce module. β°
π§° Provides ways of testing whether a given value can be a valid file/directory name. π
π An npm module that strongly types file paths! π₯
π Provides recursive readdir() and readdirSync() functions. π
Provided by Igor DimitrijeviΔ (@igorskyflyer).