getsetdeep
Get and set nested variables of an object, includes support for Backbone Models
Usage
Complete API Documentation.
Example
import { setDeep, getDeep } from 'getsetdeep'
const obj = {
a: {
b: {
c: 3,
},
},
}
console.log(getDeep(obj, 'a.b.c'))
console.log(setDeep(obj, 'a.b.c', 4))
console.log(getDeep(obj, 'a.b.c'))
Notes
setDeep
also has a fourth argument opts
for options, currently we support the options:
onlyIfEmpty
defaults to false
, if specified to true
then setDeep
will only set the value if the current value is null
or undefined
- We also work with getters
get(key)
and setters set(attrs, opts)
, enabling support for Backbone.js models as well as others
Security
To satisfy the egos of some security researchers, just as you wouldn't do obj[prompt('some user input')] = 'value'
don't do setDeep(obj, prompt('some user input'), 'value')
, obviously. Rather than getsetdeep
preventing __proto__
access, we assume the consumers of this library are intelligent enough to do what they intend.
Install
- Install:
npm install --save getsetdeep
- Import:
import * as pkg from ('getsetdeep')
- Require:
const pkg = require('getsetdeep')
import * as pkg from 'https://unpkg.com/getsetdeep@^5.1.0/edition-deno/index.ts'
<script type="module">
import * as pkg from '//cdn.skypack.dev/getsetdeep@^5.1.0'
</script>
<script type="module">
import * as pkg from '//unpkg.com/getsetdeep@^5.1.0'
</script>
<script type="module">
import * as pkg from '//dev.jspm.io/getsetdeep@5.1.0'
</script>
This package is published with the following editions:
getsetdeep
aliases getsetdeep/index.cjs
which uses the Editions Autoloader to automatically select the correct edition for the consumer's environmentgetsetdeep/source/index.ts
is TypeScript source code with Import for modulesgetsetdeep/edition-browsers/index.js
is TypeScript compiled against ES2022 for web browsers with Import for modulesgetsetdeep/edition-es2022/index.js
is TypeScript compiled against ES2022 for Node.js 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modulesgetsetdeep/edition-es5/index.js
is TypeScript compiled against ES5 for Node.js 4 || 6 || 8 || 10 || 12 || 14 || 16 || 18 || 20 || 21 with Require for modulesgetsetdeep/edition-es2022-esm/index.js
is TypeScript compiled against ES2022 for Node.js 12 || 14 || 16 || 18 || 20 || 21 with Import for modulesgetsetdeep/edition-deno/index.ts
is TypeScript source code made to be compatible with Deno
History
Discover the release history by heading on over to the HISTORY.md
file.
Contribute
Discover how you can contribute by heading on over to the CONTRIBUTING.md
file.
Backers
Maintainers
These amazing people are maintaining this project:
No sponsors yet! Will you be the first?
Contributors
These amazing people have contributed code to this project:
Discover how you can contribute by heading on over to the CONTRIBUTING.md
file.
License
Unless stated otherwise all works are:
and licensed under: