简单介绍一下js的防篡改对象:
(1)不可扩展对象(不能添加,可以修改和删除)
默认情况下,所有对象都是可扩展的。即任何时候我们都可以为对象添加属性和方法。但使用Object.preventExtensions()方法可以改变这一默认行为,即不能再为对象添加新的属性和方法,但是仍然可以修改和删除已有成员。另外,可以使用Object.isExtensible()方法检测对象是否可以扩展。
(2)密封的对象(sealed object)(不能添加和删除,可以修改)
密封的对象不可扩展,并且已有成员的[Configurable]属性被设置为false,这就意味着不能删除属性和方法。使用Object.seal()方法密封对象,使用Object.isSealed()检测对象是否被密封;
(3)冻结的对象(不能添加、删除和修改)
最严格的防篡改级别是冻结对象(frozen object)。对象一旦被冻结,则此对象既不可扩展,又是被密封的,而且对象数据属性的【【Writable】】被设置为false。如果定义【【set】】函数,访问器属性仍然是可写的。使用Object.freeze()冻结对象,使用Object.isFrozen()方法检测对象是否被冻结。
备注:参考《js 高3》