Allows you to easily create computed observables from async functions or Promises.
Dependencies between async computeds are automatically tracked by Knockout, just like any other computed. If an older async operation takes longer than a more recent one, the older one is automatically cancelled (the Promise rejected), ensuring you always get the most current value, and at the correct time.
Combine this library with a memoize library to reduce repeat network calls to the same resource.
// Adds the extender to ko.extenders
registerAsyncComputed(ko)
// Pass async function or regular function that returns Promise
const items = ko.computed(async () => {
// Do something here
return fetch("/api/entities.json")
.then(r => r.json())
}).extend({async: []}) // Provide initial value. This is used until the async function is completed for the first time
import { asyncComputed } from "knockout-async-computed"
// Create using factory function
// Pass async function or regular function that returns Promise
const items = asyncComputed(async () => {
// Do something here
return fetch("/api/entities.json")
.then(r => r.json())
}, []) // Provide initial value as 2nd argument
If you wish to compile the module yourself:
Run npm install
to download dependencies, then run npm run build
Run npm test
to run tests.
This project is licensed under the MIT License - see the LICENSE.md file for details