点击链式promise调用-场景:三个接口依次调用

<template>
  <div @click="getproise">
    点击链式promise调用-场景:三个接口依次调用--省市区
  </div>
</template>
<script>
export default {
  data(){
    return{

    }
  },
  methods: {
    getProvince(){
        var that = this;
        return new Promise(function(resolve, reject){
            //做一些异步操作
            that.$allAxios(that, 'getProvince', {
              xx: '',
              xx: '',
            }, (res) => {
              resolve(res.data.data)   //成功
            },(fail)=>{
              console.log(fail.data)   //失败
              reject(fail.data.errorMsg);
            })
        });          
    },
    getCity(data){
      var that = this;
      return new Promise(function(resolve, reject){
        //做一些异步操作
        that.$allAxios(that, 'getCity', {
          xx: ''
        }, (res) => {
          resolve(res.data.data)   //成功
        },(fail)=>{
          console.log(fail.data)   //失败
          reject(fail.data.errorMsg);
        })
      }); 
    },
    getDistrict(data){
      var that = this;
      return new Promise(function(resolve, reject){
          //做一些异步操作
          that.$allAxios(that, 'getDistrict', {
            xx: ''
          }, (res) => {
            resolve(res.data.data)   //成功
          },(fail)=>{
            console.log(fail.data)   //失败
            reject(fail.data.errorMsg);
          })
      });           
    },
    getproise(){
      this.getProvince()
      .then((data)=>{
        return this.getCity(data) // 成功进入这里
      })
      .then((data)=>{
        return this.getDistrict(data)// 成功进入这里
      })
      .catch((err)=>{
        console.log(err)  // 失败进入这里
      })
    }
  },
}
</script>
/* vue 接口封装 */
function allAxios(_this, url, data, resp, down, fail, isYapi) {
    let new_url = baseUrl + apiUrl.api[url]
    new_url = isYapi ? yapi + apiUrl.api[url] : new_url
    data = _this.$qs.stringify(data);
    axios({
        url: new_url,
        data: data,
        headers: {
            'Content-Type': 'application/x-www-form-urlencoded; charset=utf-8'
        },
        method: isYapi ? 'GET' : 'POST',
    }).then(res => {
        if (res.data.success == 0) {
            _this.$toast({
                message: res.data.errorMsg,
                 duration: 1000
             })
            down && down.call(this, res)
        } else if (res.data.success == 1) {
            resp(res)
        }
    })
}
调用:
this.$allAxios(this, 'url路径名', {  // data传参
	xxx:xxx,
	xxx:xxx
},(res) => {
	
},down => {}, fail => {})
  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值