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 对象添加属性前为何能看到该属性?的详细内容,更多请关注其它相关文章!