Skip to content

JavaScript Client

Platforms

The JavaScript client is compatible with:

Don't know NodeJS build-systems like webpack? Just save and drop the JavaScript distribution file into your project and ignore the import statements presented here in the documentation.

Usage

Installing the module

Use this method if you're using a build tool (webpack, rollup, or similar)

npm install --save colyseus.js

If you're not using a build tool, it is recommended to download the release binaries from GitHub Releases

<script src="colyseus.js"></script>

Alternatively, you may include the distribution file directly by using unpkg. Make sure to replace the @x.x.x portion of it with a version compatible with your server.

<script src="https://unpkg.com/colyseus.js@0.14.0/dist/colyseus.js"></script>

Connecting to server:

import * as Colyseus from "colyseus.js"; // not necessary if included via <script> tag.

var client = new Colyseus.Client('ws://localhost:2567');

Joining to a room:

client.join("room_name").then(room => {
    console.log(room.sessionId, "joined", room.name);
}).catch(e => {
    console.log("JOIN ERROR", e);
});

Room events

Room state has been updated:

room.onStateChange((state) => {
  console.log(room.name, "has new state:", state);
});

Message broadcasted from server or directly to this client:

room.onMessage("message_type", (message) => {
  console.log(client.id, "received on", room.name, message);
});

Server error occurred:

room.onError((code, message) => {
  console.log(client.id, "couldn't join", room.name);
});

The client left the room:

room.onLeave((code) => {
  console.log(client.id, "left", room.name);
});

React Native compatibility

This client works with React Native. You need to install some aditional dependencies for compatibility and assign window.localStorage to AsyncStorage.

  • npm install buffer

// App.js
import { AsyncStorage } from 'react-native';
import { Buffer } from "buffer";
window.localStorage = AsyncStorage;
global.Buffer = Buffer;

Cocos Creator Instructions