vue如何提前进行数据获取的?

例如下面2个consle 为什么在还没有改变原始数据的时候已经能够提前获取到数据?
图片描述

<script>
  export default {
    data(){
      return {
        arr : []
      }
    },
    mounted() {
      console.log(this.arr)
      this.arr.push("123")
      console.log(this.arr)  //打印出 ["123"]
    }
  }
</script>
阅读 2.8k
3 个回答

你点哪个小蓝图标,会出现:Value below was evaluated just now。没展开的值,是不同的,展开后值全是一样的。其原因是在Chrome Console.log()点击展开数组时,会重新去读一遍内存真实的值然后显示,所以展开后都是最终值。

因此,在打印二维数组时,其实如若不展开,他显示的就是当前值,但是点击展开后,会重新去内存读值,所以展开的值,全是最终值,所以看到所有二维数组打印的都是一个值的情况。

解决方法:1、打印之前克隆对象 2. Json.Stringify转换成字符串

这个问题真的是老生常谈了...

你用 console.log(JSON.stringify(this.arr)) 再试试。

console.log(对象) 打印出来的并不是这个对象 在执行打印语句时 的状态,而是你 打开控制台查看输出结果时 的内存中该对象的状态。

我记得<<你不知道的javascript>>里提到过console.log方法是异步方法。改用断点就好了

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题