A TypeScript WebSocket client wrapper with built-in heartbeat mechanism and auto-reconnection support.
- Automatic heartbeat detection (
ping
/pong
) - Auto-reconnection on connection loss
- Page visibility-based connection management
- Strict message type checking
- Support for JSON/binary message format
- Full TypeScript support
npm install websocket-with-heartbeat
import WebSocketWithHeartbeat, { WebSocketMessage } from 'websocket-with-heartbeat'
// Initialize
const ws = new WebSocketWithHeartbeat('wss://example.com', {
debug: true
})
// Manual connection
ws.connect()
// Handle incoming messages
ws.onmessage = (event) => {
const message: WebSocketMessage = event.data
switch (message.type) {
case 'chat':
console.log('Chat message:', message.content)
break
case 'notification':
console.log('Notification:', message.text)
break
}
}
// Send message
ws.send({
type: 'chat',
content: 'Hello!',
timestamp: Date.now()
})
All messages must follow the WebSocketMessage
interface:
interface WebSocketMessage {
type: string;
[key: string]: any;
}
Note: The type
field is required for all messages. Messages not following this format will be rejected.
ping
: Used internally for heartbeat requestspong
: Used internally for heartbeat responses
interface WebSocketOptions {
heartbeatInterval?: number; // Heartbeat interval (default: 30000ms)
reconnectDelay?: number; // Delay before reconnection attempts (default: 5000ms)
timeout?: number; // Heartbeat timeout (default: 5000ms)
debug?: boolean; // Enable debug logs (default: false)
messageType?: 'json' | 'binary'; // Message format (default: 'json')
}
ws.onopen = (event: Event) => {
console.log('Connected')
}
ws.onmessage = (event: { data: WebSocketMessage }) => {
// Note: event is not a native MessageEvent
console.log('Message received:', event.data)
}
ws.onclose = (event: CloseEvent) => {
console.log('Disconnected')
}
ws.onerror = (event: Event) => {
console.log('Error occurred')
}
// Manual close
ws.close()
// Connection automatically manages based on page visibility:
// - Connects when page becomes visible
// - Disconnects when page becomes hidden
When debug: true
is set, the library will log detailed connection and message information to the console.
MIT