Socket
Book a DemoInstallSign in
Socket

last

Package Overview
Dependencies
Maintainers
1
Versions
2
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

last

A small helper for getting only the last result of an asynchronous operation you perform multiple times in a row.

latest
Source
npmnpm
Version
1.1.0
Version published
Maintainers
1
Created
Source

Ignore All But the Last Result

Pretty commonly, when performing asynchronous operations, you might fire off multiple of them, but then only care about the last result that comes back. A common example is searching:

$(searchEl).on("input", function (ev) {
    doSearch(searchEl.value).then(updateUIWithResults).done();
});

But consider this scenario:

  • The user types "do," so you send off an asynchronous search to your server for "do."
  • The user then types "g," so you send off a search for "dog."
  • The results for "dog" come back before the results for "do," so you update your UI with those.
  • But then the results for "do" come back, so you overwrite the UI with results for "do" instead of "dog!"

This isn't what you wanted! Once you sent off the search for "dog," you want to ignore any results from the previous search for "do."

Well, this package will solve your problems.

Using Last

This package's main module has as its default export a single function, last, which you can use to wrap naïve functions into smart ones that will ignore all but the last result. It works with any function that returns a Promises/A+-compliant promise. Once you do that, your code can look just as pretty as the above example, but this time it will actually be correct!

var last = require("last");

var smartSearch = last(doSearch);

$(searchEl).on("input", function (ev) {
    smartSearch(searchEl.value).then(updateUIWithResults).done();
});

The wrapped function will return a promise of the same type as that returned by the original. And once you call the wrapped function again, you will be guaranteed that previously-returned pending promises stay pending forever, so you don't have to worry about them coming back later than your new promise.

Keywords

async

FAQs

Package last updated on 30 Jul 2013

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts