递归方法实现完全冻结对象
递归算法(recursion algorithm)在计算机科学中是指一种通过重复将问题分解为同类的子问题而解决问题的方法。
Object.keys(obj)
obj:要返回器枚举自身属性的对象。
返回值:返回一个所有元素为字符串的数组,其元素来自于从给定的obj里可直接枚举的属性。
这些属性的顺序与手动遍历该对象属性时的一致。
以上是对相关知识的介绍下面是代码的实现与分析
//冻结freezeobj
// const freezeobj = Object.freeze({a:1,b:["a"]});
//在freezeobj内b数组中加入"b"
// freezeobj.b.push("b");
//打印freezeobj返回值{ a: 1, b: [ 'a', 'b' ] }说明当前只冻结了freezeobj对象并没用冻结freezeobj内部对象
// console.log(freezeobj);
//递归方法冻结对象实现方法
//创建一个为freezeobj的函数
const freezeobj = function(obj){
//冻结当前初始对象
Object.freeze(obj);
//调用数组的每个元素,并将元素传递给回调函数。
Object.keys(obj).forEach( function(key,value){
//判断返回元素是否有object类型
if ( typeof obj[key] === 'object' ) {
//冻结这个对象
freezeobj( obj[key] );
//Object.isExtensible(obj);判断一个对象是否是可扩展的返回值为false不可扩展true可扩展
console.log(Object.isExtensible(obj));
//尝试在{a:1,b:["a"]}中b数组后加入"a"
obj.b.push("a");
//如果冻结成功会打印TypeError: Cannot add property 1, object is not extensible(无法添加属性,obj不能扩展)
console.log(obj);
}
});
};
freezeobj({a:1,b:["a"]});//调用函数并传递实参