通过promise控制事件执行顺序----高德地图获取定位和天气

//利用高德地图获取天气和定位  promise实现先获取定位,拿到定位后得到的城市名获取天气

let prom = new Promise( (resolve,reject)=>{

let AMap = window.AMap;

AMap.plugin('AMap.CitySearch',()=> {

    var citySearch = new AMap.CitySearch()

    citySearch.getLocalCity( (status, result)=> {

            if (status === 'complete' && result.info === 'OK') { 

                    // 查询成功,result即为当前所在城市信息

                   resolve(result.city);

                  this.setState({

                                 city : result.city

                              })

                       }

                 })

           });

//resolve(result.city);放在这儿会报result未定义的错

});

prom.then( (cityName)=>{

let AMap = window.AMap;

//加载天气查询插件

AMap.plugin('AMap.Weather',()=> {

      //创建天气查询实例

      var weather = new AMap.Weather();

      //执行实时天气信息查询

      weather.getLive(cityName, (err, data) => {

               if(err===null && data.info==='OK'){

                   this.setState({

                           weather:data.weather,

                          temperature:data.temperature

                  })

            }

     });

});

   });

}

单独获取天气的方式

//利用高德地图提供的接口获取天气信息

getWeather = (cityName)=>{

let AMap = window.AMap;

//加载天气查询插件

AMap.plugin('AMap.Weather',()=> {

//创建天气查询实例

var weather = new AMap.Weather();

//执行实时天气信息查询

//let cityName = '杭州市';

weather.getLive(cityName, (err, data) => {

console.log( data);

//return data.weather;

if(err===null && data.info==='OK'){

this.setState({

weather:data.weather,

temperature:data.temperature

})

}

});

});

}

//单独获取定位信息

getLocation (){

let AMap = window.AMap;

AMap.plugin('AMap.CitySearch',()=> {

var citySearch = new AMap.CitySearch()

citySearch.getLocalCity( (status, result)=> {

if (status === 'complete' && result.info === 'OK') {

// 查询成功,result即为当前所在城市信息

this.setState({

city : result.city

})

}

})

})}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值