JS红皮书解读之防篡改对象

《JS红皮书解读之防篡改对象》

前言:
去年7月份在简书写的,发现后端、React中也有体现,觉得有必要在微信上分享下。

注意:一旦把对象定义为防篡改,就无法撤销了。

1.不可扩展对象
扩展指可以给对象添加属性和方法。

使用Object.preventExtensions(object)阻止对象扩展

   let a={name:'chen'}
    Object.preventExtensions(a)
    a.age=18
    console.log(a.age) //undefined
    delete a.name
    console.log(a) //{}

注意:
(1)严格模式下,不是undefined而是报错。
(2)可以删除或修改已有对象属性,但不可添加新属性

使用Object.isExtensible(object) 判断对象是否可扩展

console.log(Object.isExtensible(a))  //false

2.密封的对象(sealed object)
注意:
(1)被密封的对象不可扩展,因此可用Object.isExtensible(object)来判断
(2)可以修改,不可删除已有属性,不可添加新属性

    Object.seal(a)
    a.age=20
    delete a.name
    console.log(a.name) //chen
    a.name='ch'
    console.log(a.name) //ch

使用Object.isSealed(object)判断是否密封

3.冻结的对象(frozen object)
冻结的对象是最严格的防篡改级别,既不可扩展,也是密封的,不可修改属性。

使用Object.freeze(object)冻结对象

对于JS库作者而言,冻结对象可防止有人修改库的核心对象。

《JS红皮书解读之防篡改对象》

(完)

    原文作者:小进进
    原文地址: https://segmentfault.com/a/1190000019753617
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞