Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/sagiegurari/funcs-js
Function wrappers for enhanced behavior.
https://github.com/sagiegurari/funcs-js
async browser delay funcs-js function function-wrapper functions nodejs
Last synced: 3 months ago
JSON representation
Function wrappers for enhanced behavior.
- Host: GitHub
- URL: https://github.com/sagiegurari/funcs-js
- Owner: sagiegurari
- License: apache-2.0
- Created: 2017-04-27T21:47:27.000Z (over 7 years ago)
- Default Branch: master
- Last Pushed: 2023-01-19T17:38:27.000Z (almost 2 years ago)
- Last Synced: 2024-10-01T05:09:06.191Z (4 months ago)
- Topics: async, browser, delay, funcs-js, function, function-wrapper, functions, nodejs
- Language: JavaScript
- Size: 79.1 KB
- Stars: 2
- Watchers: 3
- Forks: 0
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- License: LICENSE
Awesome Lists containing this project
README
# funcs-js
[![NPM Version](http://img.shields.io/npm/v/funcs-js.svg?style=flat)](https://www.npmjs.org/package/funcs-js) [![CI](https://github.com/sagiegurari/funcs-js/workflows/CI/badge.svg?branch=master)](https://github.com/sagiegurari/funcs-js/actions) [![Coverage Status](https://coveralls.io/repos/sagiegurari/funcs-js/badge.svg)](https://coveralls.io/r/sagiegurari/funcs-js) [![Known Vulnerabilities](https://snyk.io/test/github/sagiegurari/funcs-js/badge.svg)](https://snyk.io/test/github/sagiegurari/funcs-js) [![Inline docs](http://inch-ci.org/github/sagiegurari/funcs-js.svg?branch=master)](http://inch-ci.org/github/sagiegurari/funcs-js) [![License](https://img.shields.io/npm/l/funcs-js.svg?style=flat)](https://github.com/sagiegurari/funcs-js/blob/master/LICENSE) [![Total Downloads](https://img.shields.io/npm/dt/funcs-js.svg?style=flat)](https://www.npmjs.org/package/funcs-js)
> Function wrappers for enhanced behavior.
* [Overview](#overview)
* [Usage](#usage)
* [once](#usage-once)
* [maxTimes](#usage-maxTimes)
* [async](#usage-async)
* [delay](#usage-delay)
* [isFunction](#usage-isFunction)
* [noop](#usage-noop)
* [ensure](#usage-ensure)
* [Installation](#installation)
* [API Documentation](docs/api.md)
* [Contributing](.github/CONTRIBUTING.md)
* [Release History](#history)
* [License](#license)
## Overview
The funcs-js provides different utility functions which enable to wrap functions and modify their behavior.This library requires no external dependencies, and it is supported for both browser and node.js environments.
## Usage
In order to use the library in browser, you first must add the relevant dependency:```html
```
When using an AMD loader (such as RequireJS) or CommonJS type loader, the funcs object is not automatically defined on the window scope.
For node.js, simply require the module as follows:
````js
var funcs = require('funcs-js');
````### 'funcs.once(fn, [options]) ⇒ function'
Ensures the provided function is invoked only once.
This is the same as calling funcs.maxTimes(fn, 1)
This function output can be chained with other funcs apis.**Example**
````js
const onlyOnceCallback = funcs.once(callback);//can also chain multiple modifications (chained functions do not require original function as argument)
const asyncOnceCallback = funcs.once(callback).async();
````### 'funcs.maxTimes(fn, times, [options]) ⇒ function'
Wraps the provided function and ensures it is invoked no more than the provided amount.
This function output can be chained with other funcs apis.**Example**
````js
const onlyOnceCallback = funcs.maxTimes(callback, 1);//can also chain multiple modifications (chained functions do not require original function as argument)
const delayedMaxTimesCallback = funcs.maxTimes(callback, 5).delay(500);
````### 'funcs.async(fn, [options]) ⇒ function'
Ensures the function is invoked only in the next cycle.
This is the same as calling funcs.delay(fn, 0)
This function output can be chained with other funcs apis.**Example**
````js
const asyncCallback = funcs.async(callback);//can also chain multiple modifications (chained functions do not require original function as argument)
const asyncOnceCallback = funcs.async(callback).once();
````### 'funcs.delay(fn, [delay], [options]) ⇒ function'
Trigger the actual function only after the provided delay.
This function output can be chained with other funcs apis.**Example**
````js
const delayedCallback = funcs.delay(callback, 500);//can also chain multiple modifications (chained functions do not require original function as argument)
const delayedMaxTimesCallback = funcs.delay(callback, 500).maxTimes(5);
````### 'funcs.isFunction([fn]) ⇒ Boolean'
Returns true if the provided argument is a function.**Example**
````js
const isFn = funcs.isFunction(myFunction);funcs.isFunction(function () {}); //true
funcs.isFunction(); //false
funcs.isFunction(5); //false
funcs.isFunction(true); //false
````### 'funcs.noop() ⇒ undefined'
Empty function.### 'funcs.ensure([fn]) ⇒ function'
Ensures a return function.
If a function is provided, it will be returned, otherwise a noop function will be returned.**Example**
````js
const handler = funcs.ensure(maybeHandler);
````
## Installation
Run npm install in your project as follows:```sh
npm install --save funcs-js
```Or if you are using bower, you can install it as follows:
```sh
bower install funcs-js --save
```## API Documentation
See full docs at: [API Docs](docs/api.md)## Contributing
See [contributing guide](.github/CONTRIBUTING.md)| Date | Version | Description |
| ----------- | ------- | ----------- |
| 2020-05-12 | v2.0.0 | Migrate to github actions, upgrade minimal node version and remove bower |
| 2019-02-08 | v1.0.18 | Maintenance |
| 2017-04-28 | v1.0.1 | Offical release |
| 2017-04-28 | v0.0.6 | Docs |
| 2017-04-28 | v0.0.5 | Rename package as funcs-js |
| 2017-04-27 | v0.0.1 | Initial release |
## License
Developed by Sagie Gur-Ari and licensed under the Apache 2 open source license.