前言
????本人上個月換工作,來到一個新公司做技術主管,成功接手了一個很大的爛攤子,無力吐槽.面臨的第一個問題,就是公司的項目剛剛上線,但是藍牙和微信之間的連接,還經常有連接不上的情況,沒有辦法,我只能優先解決這個問題,雖然我從來沒有做過小程序.
? ? 測試了一下我們的產品,發現藍牙經常會連接不上,而且搜索很慢.于是乎,我硬著頭皮去啃他原來的的源碼.本來以為不會很麻煩,結果發現,掉進了一個很大的坑里.下面我分幾篇文章來描述一下我重構時微信小程序功耗藍牙的坑:
1.藍牙的方法都是異步回調方法,不能同步執行
? ? 這不算微信小程序的坑,算是這個項目的坑,我看到我們項目代碼:
wx.closeBluetoothAdapter()// 關閉藍牙模塊
wx.openBluetoothAdapter({//初始化 藍牙模塊 成功 和 失敗的回調
? ? ? ? success: res => {
?????????????console.log('初始化藍牙成功' + res)
? ? ? ? ? ? ? ? //省略其他代碼? ? ?},
?????fail: err => {
? ? ? ? console.log("開啟模塊失敗);? ??
}?})????
因為業務邏輯,我們需要先關閉藍牙藍牙模塊,然后再重新開啟,而這里wx.closeBluetoothAdapter 本身就是一個異步函數,我們必須等他關閉完成到success 方法才能夠執行方法,所以我首先認為這是我們經常連接不上的原因.就改了這段代碼,改后如下:
//關閉當前的藍牙模塊
?wx.closeBluetoothAdapter({
?????success: (res) => {
?????????console.log("關閉藍牙模塊成功", res);
?????????//重新打開藍牙模塊
? ? ? ? ?wx.openBluetoothAdapter({ //初始化 藍牙模塊 成功 和 失敗的回調
? ? ? ? ? success: res => {
? ? ? ? ? ? ? ? ? ? ? ? ?console.log('初始化藍牙成功', res)
????????????}, fail: err => {
? ? ? ? ? ? ? ? ? ? console.log('初始化藍牙是否開啟:', err);
????????????}, complete: function(res) {
?????????????????????console.log('初始化藍牙執行完成:', res) }
? ? ? ?})
?}, fail: (err) => {
????? console.log("關閉藍牙模塊出錯", err);
?},
?complete: (res) => {
?console.log("關閉藍牙模塊完成的", res); // ignore
},???
});
改完以后,藍牙連不上的問題確實改善了很多,我當時也是滿心歡喜的提交了代碼,拿著機器給領導演示了一下,感覺搞定了.
但是馬上就有一大波的坑正在接近,下篇文章繼續