在浏览器端,耗时很长的操作都应该异步执行,避免浏览器失去响应,最好的例子就是Ajax操作。在服务器端,"异步模式"甚至是唯一的模式,因为执行环境是单线程的,如果允许同步执行所有http请求,服务器性能会急剧下降,很快就会失去响应。
最近在小程序开发中也遇到了这个问题,主要wx.openBluetoothAdapter
这个函数,js认为其太消耗时间,就先跳过运行,但是我们需要在这个函数中得知蓝牙到底有没有打开,下面就开始介绍如何处理异步。
callback
实例代码如下:
openblue: function (callback) {
var that = this;
console.log("openblue运行")
wx.openBluetoothAdapter({
success: function(res) {
console.log("蓝牙打开成功", res);
callback(true);
},
fail: function(res) {
console.log("蓝牙未打开");
wx.showToast({
title: '请先打开蓝牙',
image: '../../images/蓝牙.svg',
mask: true
})
callback(false);
}
});
通过callback会调的方式可以使函数运行wx.openBluetoothAdapter
函数返回true或者false之后再执行接下来的函数,如果我们在代码中并没有使用callback,而是使用return直接返回结果的话,得到的结果将会是None。