Vue中 axios 如何实现发送请求后,成功获取结果后,再继续执行后面的操作

发布于 2022-09-11 17:45:44 字数 238 浏览 17 评论 0

我这有一段请求,代码如下

clipboard.png

理想状态下,应该是先输出 我是1,然后输出 我是2

不过实际情况下确实先输出了 ‘我是2’ 接下来才是‘我是1’

请问各位大佬有知道这个怎么实现吗,还是比较新的新手,不太懂,希望说的浅一点,谢谢

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(4

醉酒的小男人 2022-09-18 17:45:44

用promise或者Async/Await来实现

烟织青萝梦 2022-09-18 17:45:44
getProjectForDetails() {
  **return new Promise((resolve, reject) => {**
    api.getProjectForDetails({"参数":""}).then(res => {
      this.dataList = res.dataList
      console.log('1')
      resolve(this.dataList)
    })
  **})**
},
  this.getProjectForDetails().then(res => {
    console.log('2')
  })
乖乖哒 2022-09-18 17:45:44

axios是异步吧!js是单线程语言,浏览器只分配给js一个主线程,用来执行任务(函数),但一次只能执行一个任务,这些任务形成一个任务队列排队等候执行,等这些任务执行完以后才会执行异步里的方法!
所以先执行2,再执行1!你可以在console.log('我是2') 后面再写console.log('我是3') console.log('我是4')
出来的结果是 2 3 4 1

鼻尖触碰 2022-09-18 17:45:44

ajax请求是异步的,所以先输出2 再输出1

把需要做的操作放到成功的回调中就行了

~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文