总有一天你的谜底会解开 2022-10-04 16:02 采纳率: 77.4%
浏览 18
已结题

js中Object.defineProperty小问题

问题遇到的现象和发生背景

js中Object.defineProperty方法,按下方代码块这样用时,在控制台获取person.name会出现堆栈溢出错误,但是我把代码中Object.defineProperty第二个参数由'name'改成name时,就可以从控制台访问和修改。这是为什么?

<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <script src="../js/vue.js"></script>
    <title>Title</title>
</head>
<body>
<script>
    let person={
        name:'张三',
        number:'123'
    }
    Object.defineProperty(person,'name',{//当由'name'改为name时就可以通过控制台访问到
        get:function(){
            return person.name
        },
        set:function(newValue){
            person.name=newValue
        },
    })
</script>
</body>
</html>
  • 写回答

3条回答 默认 最新

  • 关注

    第二个参数可以是普通字符串或字符串变量。’name‘表示person里的属性,而name是一个变量,可以看到上下文没有声明这个变量,为什么没报错呢?只因为这个name存在另一个内部文件,并且值为“”。

    img

    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(2条)

报告相同问题?

问题事件

  • 系统已结题 10月12日
  • 已采纳回答 10月4日
  • 创建了问题 10月4日