ES6 const实现真正对象常量:属性不可扩展、删除与修改

0 下载量 191 浏览量 更新于2024-08-30 收藏 274KB PDF 举报
本文将深入探讨JavaScript中如何实现真正的对象常量,尤其是在ES6引入const关键字后,尽管它可以声明基本类型的常量,但对复杂类型(如对象)并不适用。文章分为两部分: 1. **基本类型常量**:const关键字用于声明基本类型(如Number、String、Boolean)的常量时,一旦赋值就不可更改。例如: ```javascript const name = 'jack'; name = 'lucy'; // 报错,因为const不允许修改已声明的变量 ``` 2. **复杂类型常量(对象)**:直接使用const声明对象时,虽然不能修改对象本身,但其属性可以被添加、修改和删除: ```javascript const Obj = { name: 'jack' }; Obj.name = 'lucy'; // 可以修改属性 Obj.age = 23; // 可以扩展属性 delete Obj.age; // 可以删除属性 Obj = { name: 'sam' }; // 会创建新的对象引用,原对象不受影响 ``` 为了实现真正的对象常量,我们需要采取特定的方法: - **阻止属性扩展**:使用`Object.preventExtensions(Obj)`,如: ```javascript Object.preventExtensions(Obj); Obj.age = 23; // 结果为undefined,扩展失败 ``` - **防止属性删除**:结合`Object.seal(Obj)`,不仅阻止扩展,还防止属性删除,如: ```javascript Object.seal(Obj); delete Obj.name; // 结果为jack,删除失败 ``` 通过以上步骤,我们可以创建一个常量对象,确保其属性在声明后既不会被扩展,也不会被删除或修改,从而满足真正的对象常量需求。这种技巧在处理需要保护数据不变性的场景中非常有用。