javascript里的get/set

下面这个是一种怎样的写法,为啥能执行?
clipboard.png

下面的为啥会报错:

clipboard.png

clipboard.png

clipboard.png
以上那样写就会出现栈溢出的情况:

clipboard.png

阅读 3.2k
2 个回答

1、var num = 20
全局作用域下这种方式定义的window上的属性,其configurable为false,所以你再defineProperty就会报错;
window.num = 20
这种方式定义的属性,其configurable为true;

2、在get中用this.这种方式去取值相当于无限循环调用get,在set中相当于无限循环调用get,所以会报错;

之所以第一个可以,是因为你操作的始终是一个全局变量,不存在循环引用的问题;

个人认为是window对象访问器属性的不能定义,换个对象试试

   var person = {
        num:20,
        age:1
    }
    Object.defineProperty(person,"num",{
        get:function(){
            return this.num;
        },
        set:function(val){
            console.log(this);
            if(val > 100){
                this.age = new Date().getFullYear() - val;
            }else{
                this.age = val;
            }
        }
    })
    person.num = 1995;
    console.log(person.age);
撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题