javascript面向对象(七)

<!doctype html>
<html>
  <head>
    <title>标题</title>
    <meta charset="utf-8">
    <script>
      "use strict";
      var emp={
        id:1001,
        name:"eric",
        salary:10000
      };
      //id属性设置为只读
      //salary属性设置为禁止遍历
      //添加age属性,值为25,可读写,可遍历,可配置
      Object.defineProperties(emp,{
        id:{
          writable:false,
          configurable:false
        },
        salary:{
          enumerable:false,
          configurable:false,
        },
        age:{
          value:25,
          writable:true,
          enumerable:true,
          configurable:true
        }
      });
      //emp.id=1002;//报错!
      //delete emp.id;//报错!
      for(var key in emp){
        console.log(key+":"+emp[key]);
      }
      emp.age++;
      console.log(emp.age);//26
      /*设置id属性为只读
      Object.defineProperty(emp,"id",{
        writable:false,
        configurable:false//不可逆
      });*/
      //delete emp.id;//禁止删除
      /*
      var id_attrs=
      Object.getOwnPropertyDescriptor(
        emp,"id"
      );
      console.dir(id_attrs)
      */
      /*
      Object.defineProperty(emp,"id",{
        writable:true
      });//报错: 不允许重定义id属性
      */
      //emp.id=1002;//报错:不允许给只读属性赋值
      //console.log(emp.id);
      //设置salary属性不可遍历:
      /*
      Object.defineProperty(
        emp,"salary",{
          enumerable:false,
          configurable:false,
        }
      );
      for(var key in emp){
        console.log(key+":"+emp[key]);
      }
      console.log(emp.salary);
      */
      /*
      Object.defineProperty(emp,"age",{
        value:25,
        writable:true,
        enumerable:true,
        configurable:true,
      });
      console.dir(
        Object.getOwnPropertyDescriptor(
          emp,"age"
        )
      );
      emp.age++;
      console.log(emp.age);
      */
    </script>
  </head>
  <body>
    
  </body>
</html>

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值