js | 作用域

前置知识

作用域

const对象怎么禁止修改

  • 方法一: Object.freeze
  • 方法二:defineProperty+递归,对于每个节点都有:writable:false
javascript 复制代码
const obj={
    a1:{
        b1:{
            c1:'c1'
        }
    },
    a2:{
        b1:{
            c1:'c2'
        },
        b2:[]
    },
}

// solution1: Object.freeze(obj)
// Object.freeze(obj);
// obj.a2="new"
// console.log(obj)


function myFoo(obj){
    if(!obj){
        return;
    }
    Object.keys(obj).forEach(key=>{
        if(typeof obj[key]==="object"){
            Object.defineProperty(obj,key,{
                writable:false
            });
            myFoo(obj[key]);
        }
        
    });
}

myFoo(obj);
obj.a2="new"
console.log(obj)
相关推荐
江城开朗的豌豆1 分钟前
Git分支管理:从'独狼开发'到'团队协作'的进化之路
前端·javascript·面试
GIS之家2 分钟前
vue+cesium示例:3D热力图(附源码下载)
前端·vue.js·3d·cesium·webgis·3d热力图
幽蓝计划3 分钟前
鸿蒙Next仓颉语言开发实战教程:下拉刷新和上拉加载更多
前端
红衣信4 分钟前
电影项目开发中的编程要点与用户体验优化
前端·javascript·github
LeeAt9 分钟前
npm:详细解释前端项目开发前奏!!
前端·node.js·html
山有木兮木有枝_11 分钟前
JavaScript对象深度解析:从创建到类型判断 (上)
前端
追风赶月、18 分钟前
【QT】信号和槽
开发语言·qt
wodownload218 分钟前
CS003-2-2-perfermance
java·开发语言·jvm
crary,记忆19 分钟前
MFE(微前端) Module Federation:Webpack.config.js文件中每个属性的含义解释
前端·学习·webpack
清风~徐~来21 分钟前
【Qt】控件 QWidget
前端·数据库·qt