1.0.14 • Published 2 years ago

jsmxq v1.0.14

Weekly downloads
1
License
MIT
Repository
github
Last release
2 years ago

jsmxq

JavaScript Message Xchange

Introduction:

jsmxq is very simple messaging library written in Typescript. It provides subject based message routing between objects. It was developed to be used with reactjs, but can be used with any project which needs power of messaging.

When used with react, it can enable components to receive and send messages. For more information on how to use with react pl check jsmxq-react, which is small glue between jsmxq and react. And also jsmxq-react-todo And a simple demo jsmxq-react-demo

Basics:

jsmxq provides Xchange and Subscriber classes to be used in an application.

Xchange takes care of storing received messages in a linked list and then sending them to desired listeners. Xchange expects each message to contain a subject and body. it finds the subscribers interested in message subject and calls onMessageReceive function, thus users can process messages in this function. A user can create any number of Xchange objects in application.

Subscriber is the class which receives message from user objects, transforms them into desired format and forward to Xchange. Any class which desires to receive and send messages must extend Subscriber class. A Subscriber must subscribe to Xchange to take part in messaging.

Example:

var jsmxq = require("jsmxq")
var Xchange = jsmxq.Xchange;
var Subscriber = jsmxq.Subscriber;

/*
 * Sub extends Subscribr class. Sub will take part in
 * messaging.
 */
class Sub extends Subscriber {
    msg: any;

    constructor(name: string) {
        super(name);
    }

    onMessageReceive(msg: any) {
        console.log(msg);
    }
}

let xchange = new Xchange();

//create subscriber s1 with name SUB1
let s1 = new Sub("SUB1");
//s1 wants to receive messages with subject sub1
s1.addSubject("sub1");

//create subscriber s2 with name SUB2
let s2 = new Sub("SUB2");
//s2 wants to receive messages with subject sub2
s2.addSubject("sub2");

//s1 and s2 both subscribe to xchange
xchange.subscribe(s1);
xchange.subscribe(s2);

/*s1 send messages with subject sub2, which will be received by s2*/
for(let i=0; i<10; i++) {
    s1.post("sub2", "message from s1: "+i);
}

/*s2 send messages with subject sub2*/
for(let i=0; i<10; i++) {
    s2.post("sub1", "message from s2: "+i);
}
1.0.14

2 years ago

1.0.13

2 years ago

1.0.10

3 years ago

1.0.8

3 years ago

1.0.7

3 years ago

1.0.6

4 years ago

1.0.5

4 years ago

1.0.4

4 years ago

1.0.3

4 years ago

1.0.2

4 years ago

1.0.1

4 years ago

1.0.0

4 years ago