vow

WebJar for vow

License

License

MIT
GroupId

GroupId

org.webjars.npm
ArtifactId

ArtifactId

vow
Last Version

Last Version

0.4.20
Release Date

Release Date

Type

Type

jar
Description

Description

vow
WebJar for vow
Project URL

Project URL

https://www.webjars.org
Source Code Management

Source Code Management

https://github.com/dfilatov/vow

Download vow

How to add to project

<!-- https://jarcasting.com/artifacts/org.webjars.npm/vow/ -->
<dependency>
    <groupId>org.webjars.npm</groupId>
    <artifactId>vow</artifactId>
    <version>0.4.20</version>
</dependency>
// https://jarcasting.com/artifacts/org.webjars.npm/vow/
implementation 'org.webjars.npm:vow:0.4.20'
// https://jarcasting.com/artifacts/org.webjars.npm/vow/
implementation ("org.webjars.npm:vow:0.4.20")
'org.webjars.npm:vow:jar:0.4.20'
<dependency org="org.webjars.npm" name="vow" rev="0.4.20">
  <artifact name="vow" type="jar" />
</dependency>
@Grapes(
@Grab(group='org.webjars.npm', module='vow', version='0.4.20')
)
libraryDependencies += "org.webjars.npm" % "vow" % "0.4.20"
[org.webjars.npm/vow "0.4.20"]

Dependencies

There are no dependencies for this project. It is a standalone project that does not depend on any other jars.

Project Modules

There are no modules declared in this project.

Vow NPM Version Build Status NPM Downloads

Vow is a Promises/A+ implementation. It also supports ES6 Promises specification.

Full API reference can be found at http://dfilatov.github.io/vow/.

Getting Started

In Node.js

You can install using Node Package Manager (npm):

npm install vow

In Browsers

<script type="text/javascript" src="vow.min.js"></script>

It also supports RequireJS module format and YM module format.

Vow has been tested in IE6+, Mozilla Firefox 3+, Chrome 5+, Safari 5+, Opera 10+.

Usage

Creating a promise

There are two possible ways to create a promise.

1. Using a deferred

function doSomethingAsync() {
    var deferred = vow.defer();
    
    // now you can resolve, reject, notify corresponging promise within `deferred`
    // e.g. `defer.resolve('ok');`
        
    return deferred.promise(); // and return corresponding promise to subscribe to reactions
}

doSomethingAsync().then(
    function() {}, // onFulfilled reaction
    function() {}, // onRejected reaction
    function() {}  // onNotified reaction
    );

The difference between deferred and promise is that deferred contains methods to resolve, reject and notify corresponding promise, but the promise by itself allows only to subscribe on these actions.

2. ES6-compatible way

function doSomethingAsync() {
    return new vow.Promise(function(resolve, reject, notify) {
        // now you can resolve, reject, notify the promise
    });
}

doSomethingAsync().then(
    function() {}, // onFulfilled reaction
    function() {}, // onRejected reaction
    function() {}  // onNotified reaction
    );

Extensions and related projects

  • vow-fs — vow-based file I/O for Node.js
  • vow-node — extension for vow to work with nodejs-style callbacks
  • vow-queue — vow-based task queue with weights and priorities
  • vow-asker — wraps asker API in the vow promises implementation

NOTE. Documentation for old versions of the library can be found at https://github.com/dfilatov/vow/blob/0.3.x/README.md.

Versions

Version
0.4.20
0.4.12
0.4.8