-
-
Notifications
You must be signed in to change notification settings - Fork 641
Promise
Represents an ECMAScript 6 compliant Promise/A+ implementation.
return new Dexie.Promise(function (resolve, reject) {
// Do something and call resolve / reject when done.
}).then(function (result) {
// This code is called if resolve() was called in the Promise constructor
}).catch(function (error) {
// This code is called if reject() was called in the Promise constructor, or
// if an exception was thrown in either constructor or previous then() call.
}).finally(function () {
// This code will be called no matter if an error occurred or not.
});
Implementation of a Promise/A+ documented at https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise
Dexie.Promise can be used in conjunction with the standard Promise implementation in ES6 as well as Q- and other A+ compatible Promise implementations in both directions.
Mix with any thenable implementation:
db.cars.where('brand').equals('Volvo'}).then( function(cars) {
// Post my cars to the server:
return jQuery.ajax({
url: "foobar",
data: cars,
type: 'post'
}); // Another promise is returned
}).then(function(response) {
// Handle successful ajax response
}).catch(function(error) {
// Handle error
});
new window.Promise(function(resolve, reject) {
resolve("something");
}).then(function (x) {
console.log(x);
return db.cars.where('brand').equals('Volvo'});
}).then( function(cars) {
// Here we get the cars array from Dexie,
// delivered throught the standard Promise implementation.
console.log(cars.join(JSON.stringify));
}).catch(function(error) {
// Handle error standardized
});
...but avoid it within transactions:
db.transaction('rw', db.cars, function () {
//
// Transaction block
//
db.cars.put({id: 3}).then (function() {
// Avoid returning other kinds of promises here:
return new window.Promise(function(resolve, reject){
resolve();
});
}).then(function() {
// You'll successfully end-up here, but any further call to db
// will fail with "Transaction Inactive" error.
return db.cars.get(3); // WILL FAIL WITH TRANSACTION INACTIVE!
});
});
The main reason for not using it within transactions is due to an incompatibility between the IndexedDB specification and the Promise specification. Another reason is that only Dexie.Promise has the capability to keep track of the currently executing transaction between calls.
This implementation is a fork of promise-light (https://github.com/taylorhakes/promise-light) by https://github.com/taylorhakes - an A+ and ECMASCRIPT 6 compliant Promise implementation.
Modified by David Fahlander to be indexedDB compliant (See discussion: https://github.com/promises-aplus/promises-spec/issues/45).
This implementation will resolve/reject the promise directly without going through setTimeout(fn, 0) when it's not needed. The use of setTimeout(fn,0) is only needed if resolve() / reject() was called in same tick as the constructor. The behavior is still 100% Promise/A+ compliant and the caller of new Promise() can be certain that the promise wont be triggered the lines after constructing the promise.
This topic was also discussed in the following thread: https://github.com/promises-aplus/promises-spec/issues/45 and this implementation solves that issue.
See also https://developer.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/Promise
Dexie.js - minimalistic and bullet proof indexedDB library