javascript防止对象被修改

对象类型/操作增加删除修改
初始对象TTT
不可扩展对象FTT
封闭对象FFT
冷冻对象FFF

一、不可扩展对象

        window.onload = function(){
            var test = {
                name: 'tom',
                father: 'bob'
            }

            /*
            * 初始对象
            */
            console.log(Object.isExtensible(test));//初始可扩展
            console.log(Object.isSealed(test));//初始不是封闭
            console.log(Object.isFrozen(test));//初始不冻结
            test.age = '29';//可以增
            console.log(test.age);
            delete test.age;//可以删
            console.log(test.age);
            test.name = 'alice';//可以改
            console.log(test.name);
            console.log("=======================================")

            /*
            *  不可扩展对象
            */
            Object.preventExtensions(test); 
            console.log(Object.isExtensible(test));//不可扩展
            test.age = '29';//不可增
            console.log(test.age);
            delete test.father;//可以删
            console.log(test.father);
            test.name = 'happy';//可以改
            console.log(test.name);
            console.log("----------------------------------------")

            /*
            *  封闭对象
            */
            // Object.seal(test); 
            // console.log(Object.isExtensible(test));//不可扩展
            // console.log(Object.isSealed(test)); //封闭
            // test.age = '29';//不可增
            // console.log(test.age);
            // delete test.name;//不可删
            // console.log(test.name);
            // test.name = 'happy';//可以改
            // console.log(test.name);
            // console.log("----------------------------------------")

            /*
            *  冻结对象
            */
            // Object.freeze(test); 
            // console.log(Object.isExtensible(test));//不可扩展
            // console.log(Object.isSealed(test)); //封闭
            // console.log(Object.isFrozen(test)); //冻结
            // test.age = '29';//不可增
            // console.log(test.age);
            // delete test.name;//不可删
            // console.log(test.name);
            // test.name = 'happy';//不可改
            // console.log(test.name);
            // console.log("----------------------------------------")
        }

二、密封的对象

        window.onload = function(){
            var test = {
                name: 'tom',
                father: 'bob'
            }

            /*
            * 初始对象
            */
            console.log(Object.isExtensible(test));//初始可扩展
            console.log(Object.isSealed(test));//初始不是封闭
            console.log(Object.isFrozen(test));//初始不冻结
            test.age = '29';//可以增
            console.log(test.age);
            delete test.age;//可以删
            console.log(test.age);
            test.name = 'alice';//可以改
            console.log(test.name);
            console.log("=======================================")

            /*
            *  不可扩展对象
            */
            // Object.preventExtensions(test); 
            // console.log(Object.isExtensible(test));//不可扩展
            // test.age = '29';//不可增
            // console.log(test.age);
            // delete test.father;//可以删
            // console.log(test.father);
            // test.name = 'happy';//可以改
            // console.log(test.name);
            // console.log("----------------------------------------")

            /*
            *  封闭对象
            */
            Object.seal(test); 
            console.log(Object.isExtensible(test));//不可扩展
            console.log(Object.isSealed(test)); //封闭
            test.age = '29';//不可增
            console.log(test.age);
            delete test.name;//不可删
            console.log(test.name);
            test.name = 'happy';//可以改
            console.log(test.name);
            console.log("----------------------------------------")

            /*
            *  冻结对象
            */
            // Object.freeze(test); 
            // console.log(Object.isExtensible(test));//不可扩展
            // console.log(Object.isSealed(test)); //封闭
            // console.log(Object.isFrozen(test)); //冻结
            // test.age = '29';//不可增
            // console.log(test.age);
            // delete test.name;//不可删
            // console.log(test.name);
            // test.name = 'happy';//不可改
            // console.log(test.name);
            // console.log("----------------------------------------")
        }

三、冻结的对象

        window.onload = function(){
            var test = {
                name: 'tom',
                father: 'bob'
            }

            /*
            * 初始对象
            */
            console.log(Object.isExtensible(test));//初始可扩展
            console.log(Object.isSealed(test));//初始不是封闭
            console.log(Object.isFrozen(test));//初始不冻结
            test.age = '29';//可以增
            console.log(test.age);
            delete test.age;//可以删
            console.log(test.age);
            test.name = 'alice';//可以改
            console.log(test.name);
            console.log("=======================================")

            /*
            *  不可扩展对象
            */
            // Object.preventExtensions(test); 
            // console.log(Object.isExtensible(test));//不可扩展
            // test.age = '29';//不可增
            // console.log(test.age);
            // delete test.father;//可以删
            // console.log(test.father);
            // test.name = 'happy';//可以改
            // console.log(test.name);
            // console.log("----------------------------------------")

            /*
            *  封闭对象
            */
            // Object.seal(test); 
            // console.log(Object.isExtensible(test));//不可扩展
            // console.log(Object.isSealed(test)); //封闭
            // test.age = '29';//不可增
            // console.log(test.age);
            // delete test.name;//不可删
            // console.log(test.name);
            // test.name = 'happy';//可以改
            // console.log(test.name);
            // console.log("----------------------------------------")

            /*
            *  冻结对象
            */
            Object.freeze(test); 
            console.log(Object.isExtensible(test));//不可扩展
            console.log(Object.isSealed(test)); //封闭
            console.log(Object.isFrozen(test)); //冻结
            test.age = '29';//不可增
            console.log(test.age);
            delete test.name;//不可删
            console.log(test.name);
            test.name = 'happy';//不可改
            console.log(test.name);
            console.log("----------------------------------------")

四、深冻结

<!DOCTYPE html>
<html>
    <head>
        <meta charset="utf-8" />
        <title>js 深冻结 与 浅冻结</title>
    </head>
    <body>
        <script type="text/javascript">
            function deepFreeze(o) {
                var prop, propKey
                Object.freeze(o) // 首先冻结第一层对象
                for (propKey in o) {
                    prop = o[propKey]
                    if (!o.hasOwnProperty(propKey) || !(typeof prop === "object") || Object.isFrozen(prop)) {
                        // 跳过原型链上的属性、基本类型和已冻结的对象.
                        continue
                    }
                    deepFreeze(prop) //递归调用.
                }
            }
        </script>
    </body>
</html>

 

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值