vue ajax 获取数据前的加载中

clipboard.png
clipboard.png

clipboard.png

clipboard.png
看了网上的写法,我执行有报错是为什么呀?

阅读 3.9k
5 个回答

fakeAjaxsetTimeout 里的this 指向不对

报错说this.toggleLoading不是function。是因为在setTimeout内部this指向改变了。你需要在外部赋值一下。比如V=this。然后再setTimeout中用v.toggleLoading

this有问题,这里this不是vue对象,是window对象,改为v.toggleLoading
图片描述

this作用域的问题。
setTimeout中的this对象是window对象。
应该在setTimeout外面用一个变量将vue对象保留,用于setTimeout中再调用。

以上答案的意思是

let that = this
setTimeout(function(){
    that.toggleLoading(false)
}, 1500)

或者

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