在移动端使用一般会使用indexedDB,来缓存数据,来提高用户体验。在之前一直都很正常,但是更新到14.6之后,不正常了。
经多次测试排查,确认是IndexedDB 既没有触发onerror
也没有触发onsuccess
,导致程序一直在等待。
目前发现很多人都遇到此问题,目前没有很好的解决手段。 只能设置一个超时的时间,时间到了,就当失败处理。
// 类似伪代码
async openDb(){
return new Promise(resolve => {
const request = indexedDB.open('dbname', 1)
request.onerror = function(event) {
resolve({
success: false,
event: event
})
}
request.onsuccess = event => {
resolve({
success: true,
db: request.result
})
}
setTimeout(() => {
resolve({
success: false
})
}, 200)
})
}
const { success, db } = await openDb()
if(success){
//db.add
//db.put
}
上面的代码,是目前权宜之计。只能等待官方出解决方案。
经过实测,升级到iOS 14.7的遇到此问题的概率会小。iOS 15 beta版目前没有这个这个问题。
目前苹果的开发这论坛和其他的论坛都有人反馈这样的问题。
https://developer.apple.com/forums/thread/681201
https://forum.ionicframework.com/t/indexeddb-in-latest-ios/210306