Package Exports
- @steelbreeze/delegate
This package does not declare an exports field, so the exports above have been automatically detected and optimized by JSPM instead. If any package subpath is missing, it is recommended to post an issue to the original package (@steelbreeze/delegate) to support the "exports" field. If that is not possible, create a JSPM override to customize the exports field for this package.
Readme
delegate
Multicast delegate for TypeScript and JavaScript.
If you like delegate, please star it...
Install
npm i @steelbreeze/delegateUsage
TypeScript
import { create as delegate } from "@steelbreeze/delegate";
const a = delegate(param => console.log(param + " Hello"), param => console.log(param + " World "));
const b = delegate(param => console.log(param + " Hello world"));
const c = delegate(a, b);
a("a")
b("b")
c("c");JavaScript
var delegate = require("@steelbreeze/delegate");
var a = delegate.create(function (param) { console.log(param + " Hello"); }, function (param) { console.log(param + " World "); });
var b = delegate.create(function (param) { console.log(param + " Hello world"); });
var c = delegate.create(a, b);
a("a");
b("b");
c("c");Output
The output of the above code will be:
a Hello
a World
b Hello world
c Hello
c World
c Hello worldAPI
Interfaces
Delegate
A prototype for a delegate function that is callable and may return a value.
interface Delegate<TReturn = any> {
(...args: any[]): TReturn
}MulticastDelegate
A prototype for a multicast delegate function that calls multiple delegates and returns all their return values as an array.
interface MulticastDelegate<TReturn = any> {
(...args: any[]): TReturn[]
}Functions
create
Creates a new delegate from one or more functions or delegates, the result of which is callable and when called returns an array of all the return values from those functions or delegates.
create<TReturn = any>(...delegates: Delegate<TReturn>[]): MulticastDelegate<TReturn>License
MIT License
Copyright (c) 2017 David Mesquita-Morris