I installed iOS 8 on a third-generation iPad and tried IndexedDB in Safari. My sample code just adds 1000 objects to the object store.
It works, but it is very slow compared to other devices with similar or weaker equipment.
See this snippet for implementation details (IndexedDB seems to be disabled in stackoverflow, so the example doesn't work out of the box - use this script instead):
The jsbin snippet is added because jsfiddle raises a SecurityException on the iOS device and is updated using Deni Spasovskis http://jsbin.com/jorohe/1/ . The problem still persists.
Original code:
var openRequest = window.indexedDB.open("testdb");
openRequest.onsuccess = function (event) {
document.getElementById("output").innerHTML += "open success<br/>";
var db = event.target.result;
var trans = db.transaction(["testStore"], (typeof IDBTransaction.READ_ONLY !== "undefined") ? IDBTransaction.READ_WRITE : "readwrite" );
var store = trans.objectStore("testStore");
var reqClear = store.clear();
reqClear.onsuccess = function () {
var objectsToAdd = 1000;
var addedObjects = 0;
var startTime = window.performance.now();
for (var i=0; i<objectsToAdd; i++) {
(function (pos) {
var req = store.add({testID: pos, a: "foo", b: "bar"});
req.onsuccess = function () {
addedObjects++;
if (addedObjects >= objectsToAdd) {
document.getElementById("output").innerHTML += "done adding<br />";
document.getElementById("output").innerHTML += "Took: "+(window.performance.now() - startTime)+"ms<br />";
}
}
req.onerror = function () {
document.getElementById("output").innerHTML += "error adding element:" + req.error + " <br/>";
}
})(i);
}
}
reqClear.onerror = function () {
document.getElementById("output").innerHTML += "error clearing store: "+reqClear.error+"<br/>";
}
};
openRequest.onupgradeneeded = function (event) {
var db = event.target.result;
var objectStore = db.createObjectStore("testStore", { keyPath: "testID" });
document.getElementById("output").innerHTML += "created store<br/>";
};
openRequest.onerror = openRequest.onabort = function () {
document.getElementById("output").innerHTML += "error opening db<br/>";
}
<div id="output">
</div>
Run codeHide resultiPad 6 , Internet Explorer HTC Windows Phone 8s ( ) 1,5 , Chrome Samsung Galaxy S III ( iPad) 300 .
, iOS, .
- IndexedDB iOS?