@exodus/proxy-freeze
v2.0.0
Published
Simple way to freeze JavaScript objects and know of attempted modifications
Downloads
5,741
Maintainers
Readme
proxy-freeze
A simple way to freeze JavaScript objects and know of attempted modifications.
Why?
Why not just use Object.freeze and Object.isFrozen?
If you use Object.freeze
and later set a property on that object, it silently fails unless in strict
mode. Also, using this technique gives you the ability to listen for warnings on the warning
event.
Install
npm install --save proxy-freeze
Usage
proxyFreeze(target, options)
- target: can be either an
object
or constructorfunction
- options
- addProxyIdentifier:
boolean
, adds a symbol getter that detects Proxies created via this method. Defaults tofalse
. - preventRefreeze:
boolean
, uses symbol added viaaddProxyIdentifier
to identify frozen Proxies and doesn't re-freeze them. Defaults tofalse
.
- addProxyIdentifier:
const obj = {
name: 'jp'
}
const obj2 = proxyFreeze(obj)
obj2.name = 'bob'
process.once('warning', (warning) => {
console.warn(warning.name) // => ProxyFreezeWarning
console.warn(warning.message) // => Trying to set value of property (name) of frozen object.
console.warn(warning.stack)
})