easydot provides "dot-string access" for target object.
e.g) console.log(easydot({a:{b:{c:42}}})["a.b.c"]); // => 42
<script src="https://cdn.jsdelivr.net/gh/matsuby/easydot/dist/easydot.min.js"></script>
// Install from npm
npm install --save easydot
// Install from yarn
yarn add easydot
and
// Use ES Modules
import easydot from "easydot";
// Use Common JS
const easydot = require("easydot");
const target = {
what: {
is: {
easydot: 42
}
}
};
// create proxy that implements `dot-string acccess`
const proxy = easydot(target);
// get nested property
console.log(proxy["what.is.easydot"]);
// => 42
// set nested property
proxy["what.is.easydot"] = "set value";
console.log(proxy.what.is.easydot);
// => "set value"
// this is a just proxy, so target status was affected
proxy["what.is.name"] = "john";
console.log(JSON.stringify(target, null, 2));
// =>
// {
// "what": {
// "is": {
// "easydot": "set value",
// "name": "john"
// }
// }
// }
const target = {
what: {
is: {
easydot: 42
}
}
};
// unsafe over jump access(default)
const unsafeProxy = easydot(target);
try {
unsafeProxy["not.exist.property"];
} catch (e) {
console.error("error");
}
// safe over jump access(optional)
const safeProxy = easydot(target, true);
safeProxy["not.exist.property"] = "safe";