【求助】vue 如何把网络请求,把异步改成同步呢?

发布于 2022-09-11 22:20:32 字数 2177 浏览 17 评论 0

是uni-app制作微信小程序,遇到网络请求异步、同步的问题?

1、使用默认的uni.request请求

uni.login({
    provider: 'weixin',
    success: function (loginRes) {
        let code = loginRes.code
        
        uni.request({
            url: apiurl+"/oauth/oauth",  
            data: {code:code},
            method:'POST',
            success: (res) => {  
                console.log(res.data); 
                 if (res.data.status == 1) {
                    var results=res.data.results
                    console.log("==============================")
                    $vm.$store.commit('setSessionkey',results.sessionkey)
                    console.log("sessionkey1:"+$vm.sessionkey)
                 }
            }
        })
        console.log("sessionkey2:"+$vm.sessionkey)

    }
})

如下图,sessionkey2为空
图片描述

2、根据百度搜索后,尝试对uni.request请求进行封装

//封装uni.request
export async function post_request(url, obj) {  
    //返回一个promise实例。  
    return await new Promise((resolve, reject) => {  
        uni.request({  
            url: apiurl+url,  
            data: obj,
            method:'POST',
            success: (result) => {  
                resolve(result.data);  
            },
            fail: (e) => {  
                reject(e);  
            }  
        })  
    })  
} 
//请求数据
uni.login({
    provider: 'weixin',
    success: function (loginRes) {
        let code = loginRes.code
        
        post_request("/oauth/oauth",{code:code}).then(res => {
            console.log(res)
            if (res.status == 1) {
                var results=res.results
                console.log("==============================")
                $vm.$store.commit('setSessionkey',results.sessionkey)
                console.log("sessionkey1:"+$vm.sessionkey)
            }
        })
        console.log("sessionkey2:"+$vm.sessionkey)
    }
})

如下图,sessionkey2还是为空的
图片描述

求助,如何才能让sessionkey2正常输出呢?

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

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

发布评论

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

评论(5

未央 2022-09-18 22:20:32

简单例子,使用 Promise async await

;(async function () {
  // 2 秒后返回结果
  function demo (msg) {
    return new Promise(resolve => {
      setTimeout(() => {
        resolve(`[ok]:${msg}`)
      }, 2000)
    })
  }

  const test = await demo('异步变同步成功')
  alert(test)
})();
风吹雪碎 2022-09-18 22:20:32

uni.login({

provider: 'weixin',
success: function (loginRes) {
    let code = loginRes.code
    
    post_request("/oauth/oauth",{code:code}).then(res => {
        console.log(res)
        if (res.status == 1) {
            var results=res.results
            console.log("==============================")
            $vm.$store.commit('setSessionkey',results.sessionkey)
            console.log("sessionkey1:"+$vm.sessionkey)
        }
    }).then(() ={
        console.log("sessionkey2:"+$vm.sessionkey)
    })
    
}

})

写在下一个then里面

谷夏 2022-09-18 22:20:32
export function post_request(url, obj) {  
    //返回一个promise实例。  
    return new Promise((resolve, reject) => {  
        uni.request({  
            url: apiurl+url,  
            data: obj,
            method:'POST',
            success: (result) => {  
                resolve(result.data);
                
            },
            fail: (e) => {  
                reject(e);  
            }  
        })  
    })  
} 

post_request只需要返回一个Promise实例即可,successresolve(result.data)

//请求数据
uni.login({
    provider: 'weixin',
    success: async function (loginRes) {
        let code = loginRes.code        
        let result= await post_request("/oauth/oauth",{code:code})
        console.log(result)
    }
})

使用的时候,在 "上级函数"中加上async。然后再使用的时候加上 let result = await promiseFun()

对你再特殊 2022-09-18 22:20:32

async await牢记一下,或者axios.all

汹涌人海 2022-09-18 22:20:32
export function Promisify(func) {
  return function(data) {
    return new Promise((resolve, reject) => {
      func({
        ...data,
        success: resolve,
        fail: reject
      });
    });
  };
}

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