🦺 Object helper to get, set, delete and check nested properties without risk.
- 🚀 Lightweight.
- ⚪️ Zero dependencies.
const objeto = require("objeto");
If the targetObject
doesn't contain the path
property, it will return undefined
.
- targetObject
object
: Object to target. - path
string | Array<string>
: Dot path"prop1.prop2"
or array path["prop1", "prop2"]
.
objeto(targetObject).get(path);
objeto(targetObject).set(path, value);
const deletedValue = objeto(targetObject).delete(path);
Check if the targetObject
has the specified property.
objeto(targetObject).has(path);
Check if a property value type is equal the specified type.
objeto(targetObject).isType(path, type);
let bike = {
wheel1: {
type: "AD-56",
status: "ok"
},
wheel2: {
type: "AT-77",
status: "ok"
},
};
objeto(bike).get("wheel2.type"); // "AT-77"
objeto(bike).set("wheel2.type", "newType");
objeto(bike).delete("wheel2.type"); // "AT-77"
objeto(bike).has("wheel2.type"); // true
objeto(bike).isType("wheel2.type", "string"); // true
objeto(bike).get("wheel2.type.doesntExists"); // undefined
objeto(bike).set("wheel2.type.doesntExists.newProp", "newType"); // new nested property is created
objeto(bike).has("wheel2.type.doesntExists"); // false