JavaScript 对象添加属性前为何能看到该属性?

javascript 对象添加属性前为何能看到该属性?

javascript 中,对象添加属性前为何能看到该属性?

当创建一个 javascript 对象时,即使在添加属性之前,也可以通过点语法或方括号语法访问该属性。这是因为:

被输出的实际上是对象本身,而不是对象在输出时的状态。因此,对象后续发生的任何更改都会反映在输出结果中。

以下代码演示了这一点:

let checkedinput = {};
console.log(checkedinput);
checkedinput.addressnum = [/^.{5,20}$/, '地址必须大于等于5个字'];

输出将显示一个包含 addressnum 属性的对象,即使该属性是在输出之后添加的。

解决方法:

如果您希望输出对象在特定时间点的状态,可以先将对象转换为字符串,然后输出字符串:

let checkedInput = {};
console.log(JSON.stringify(checkedInput));
checkedInput.addressNum = [/^.{5,20}$/, '地址必须大于等于5个字'];

以上就是JavaScript 对象添加属性前为何能看到该属性?的详细内容,更多请关注其它相关文章!