Js promise 的使用

Javascript 中的 Promise 对象,可以将异步操作以同步操作的流程表达出来,避免了层层嵌套的回调函数。此外,Promise 对象提供统一的接口,使得控制异步操作更加容易。

Promise 创建
var promise = new Promise(function(resolve, reject) {
    // 异步处理
    // 处理结束后、调用resolve 或 reject
});
实例

返回 Request 请求结果

function getIp() {
    return new Promise(function (resolve, reject) {
      const request = require('request');
      request({
        url: "http://pv.sohu.com/cityjson?ie=utf-8",
        method: "GET",
      }, function (error, response, body) {
        if (response.statusCode === 200) {
          resolve(body);
        }
      });
    });
  }

// 等待 getIp 执行结束返回 ip 地址
getIp().then(function (value) {
		console.log(value);
});
async 与 await

async 将函数修饰为异步函数, 其他操作可以不等待此函数执行结束
await 修饰某一个操作,此操作执行结束,才能执行下一步

var ip = "127.0.0.1";
async setIp(){
	await getIp().then(function (value) {
		ip = value;
	});
	console.log(ip );
}

以上代码输出结果为 getIp() 获取的 ip 地址, 如果没有使用 await ,输出结果将为 127.0.0.1

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值