safe-proxy
is a Javascript utility to allow for safe accessing of nested properties by soaking up nulls, inspired by Coffeescript's existential operator. It is the spiritual successor to safe-access. My friend Palash had the genius idea of improving safe-access
’s syntax for calling functions by using ES6 Proxies. Note that since the ES6 Proxy spec is still in flux (no browsers have implemented the latest spec as of January 2015), this is not meant to be used in production. However, it’s really freakin’ cool, so try it out.
npm install safe-proxy
ES6 proxies are only supported in Node.js >= 6.0.0 and the latest major browsers (see http://kangax.github.io/compat-table/es6/#test-Proxy).
Use safe-proxy
like this:
var safe = require('safe-proxy');
safe(obj).that.is.very.nested.__value;
// the same as `obj.that.is.very.nested` EXCEPT
// returns undefined if any property in the chain is undefined
You can access arrays and call functions as you normally would. Just remember to access __value
at the end.
safe(obj).nested.property.and.array[0].func('some', 'args').__value;
You can think of calling safe(obj)
as wrapping obj
in an object which will not throw an error no matter what properties you access or functions you call on it (even if obj
is undefined, for instance). In order to unwrap the value, you’ll need to access the special property __value
.
Clone this repo, and then from directory root run npm install
. Start running tests with npm test
. Tests will re-run when files change.
safe-proxy
is freely distributable under the terms of the MIT license.