Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/jusx/object-dot
Easily use dot notation to safely get, or set a property of a nested object. A Node module.
https://github.com/jusx/object-dot
dot-notation node-module node-object node-utility object
Last synced: 3 months ago
JSON representation
Easily use dot notation to safely get, or set a property of a nested object. A Node module.
- Host: GitHub
- URL: https://github.com/jusx/object-dot
- Owner: jusx
- License: isc
- Created: 2019-02-27T07:13:56.000Z (almost 6 years ago)
- Default Branch: master
- Last Pushed: 2021-01-25T08:21:33.000Z (almost 4 years ago)
- Last Synced: 2024-10-07T00:25:35.174Z (3 months ago)
- Topics: dot-notation, node-module, node-object, node-utility, object
- Language: JavaScript
- Homepage:
- Size: 277 KB
- Stars: 1
- Watchers: 3
- Forks: 3
- Open Issues: 2
-
Metadata Files:
- Readme: README.md
- License: LICENSE.md
Awesome Lists containing this project
README
# 📦 object-dot
[![CircleCI](https://circleci.com/gh/jusx/object-dot.svg?style=svg)](https://circleci.com/gh/jusx/object-dot) [![codecov](https://codecov.io/gh/jusx/object-dot/branch/master/graph/badge.svg)](https://codecov.io/gh/jusx/object-dot) [![npm](https://img.shields.io/npm/v/object-dot.svg?style=flat-square)](https://www.npmjs.com/package/object-dot)
Easily use dot notation to `get`, or `set` a property of a nested object. A node module.
> 💥 100% code coverage, zero dependencies and flexible APIs.
# Usage
## `set`
Create the nested chain of objects with `set` and dot notation with one simple statement.
```js
const objectd = require('object-dot')console.log(
objectd.set({ object: {}, path: 'a.b.c', value: 'foo' })
)
// => { a: { b: { c: 'foo' } } }// Array of the property chain will work too!
console.log(
objectd.set({ object: {}, path: ['a', 'b', 'c'], value: 'foo' })
)// Alternatively you may use arguments as parameters instead of an object.
console.log(
objectd.set({}, 'a.b.c', 'foo')
)
```By default any property with values that exists in the path of the chained property is overwritten. The API can be instructed to not overwrite but instead do nothing when this scenario is found. Consider the following:
```js
require('object-dot').extend()
let obj = { a: { b: { c: 'foo' } } }// By default, the value for `c` is overwritten
console.log(
Object.set(obj, 'a.b.c.d', 'foo')
)
//=> { a: { b: { c: { d: 'foo' } } } }// Tell the API not to overwrite
console.log(
Object.set(obj, 'a.b.c.d', 'foo', false)
)
//=> { a: { b: { c: 'foo' } } }// Alternatively, you may call it with an object as a parameter
Object.set({ object: obj, path: 'a.b.c.d', value: 'foo', overwrite: false })
```## `get`
Get the value of a nested chain of objects without checking each object in the chain for its existence.
```js
const objectd = require('object-dot')// when one of the properties in the chain is undefined. Safely return undefined.
let object = { foo: { bar: 'you!' }}
console.log(
objectd.get({ object, path: 'foo.bar.c.d'})
)
//=> undefined// return a default value if property is undefined
object = { foo: { bar: 'you!' }}
console.log(
objectd.get({ object, path: 'foo.bar.c.d', value: 'my default value'})
)
//=> 'my default value'// When the property exist.
object = { a: { foo: { bar: 'you!' } }}
console.log(
objectd.get({ object, path: 'a.foo'})
)
//=> { bar: 'you!' }// Plain arguments as parameters will work too!
console.log(
objectd.get(object, 'a.foo.bar')
)
// => 'you!'// Using arrays instead of dot notation is also supported.
console.log(
objectd.get(object, ['a', 'foo', 'bar'])
)
// => 'you!'```
## `exists`
The `exists` method determines if a chained object exist.
```js
const objectd = require('object-dot')// when one of the properties in the chain is undefined. Safely return undefined.
let object = { foo: { bar: 'you!' }}
console.log(
objectd.exists({ object, path: 'foo.bar'})
)
//=> true// alternatively using plain old arguments work too.
console.log(
objectd.exists(object, 'foo.bar')
)```
## `extend`
Use the `extend` method to add the methods, `get`, `set` and `exists` to the Object prototype chain:
```js
require('object-dot').extend()let object = { foo: { bar: 'you!' }}
console.log(
Object.exists(object, 'foo.bar')
)
//=> true
```
# Install```bash
$ npm install object-dot --save
```# License
ISC