Socket.io-client: Socket.io - L'événement de reconnexion du client 3.0.0+ a échoué

Créé le 30 déc. 2020  ·  3Commentaires  ·  Source: socketio/socket.io-client

Socket.io - L'événement de reconnexion du client 3.0.0+ a échoué.

Passez à la version 2.3.1 et cela fonctionne.

const io = require('socket.io-client');

let socket = io.connect('ws://127.0.0.1:8000', {
    "transports": ['websocket', 'polling'],
    reconnection: true
});
socket.on('connect', function(data){
    onlineFlag = true;
    console.log(data + ' - connect');
});
socket.on('connect_error', function(data){
    console.log(data + ' - connect_error');
});
socket.on('connect_timeout', function(data){
    console.log(data + ' - connect_timeout');
});
socket.on('error', function(data){
    console.log(data + ' - error');
});
socket.on('disconnect', function(data){
    onlineFlag = false;
    console.log(data + ' - disconnect');
});
socket.on('reconnect', function(data){
    console.log(data + ' - reconnect');
});
socket.on('reconnect_attempt', function(data){
    console.log(data + ' - reconnect_attempt');
});
socket.on('reconnecting', function(data){
    console.log(data + ' - reconnecting');
});
socket.on('reconnect_error', function(data){
    console.log(data + ' - reconnect_error');
});
socket.on('reconnect_failed', function(data){
    console.log(data + ' - reconnect_failed');
});
socket.on('ping', function(data){
    console.log(data + ' - ping');
});
socket.on('pong', function(data){
    console.log(data + ' - pong');
});
question

Commentaire le plus utile

@newpanjing salut ! Qu'entendez-vous par « reconnexion de l'événement tout a échoué » ?

Comme l'a souligné @tannerkrewson (merci !), l'instance Socket n'émet plus aucun événement de reconnexion.

// no longer emitted
socket.on("reconnect_attempt", () => {});
// but you can listen to the events emitted by the Manager instance (the io attribute)
socket.io.on("reconnect_attempt", () => {});

Tous les 3 commentaires

J'ai eu ce problème aussi; j'ai compris !! C'est par conception :

https://socket.io/docs/v3/migrating-from-2-x-to-3-0/index.html#The -Socket-instance-will-no-longer-forward-the-events-emitted- par-son-gérant

@newpanjing salut ! Qu'entendez-vous par « reconnexion de l'événement tout a échoué » ?

Comme l'a souligné @tannerkrewson (merci !), l'instance Socket n'émet plus aucun événement de reconnexion.

// no longer emitted
socket.on("reconnect_attempt", () => {});
// but you can listen to the events emitted by the Manager instance (the io attribute)
socket.io.on("reconnect_attempt", () => {});

Serait-il possible d'avoir un message d'avertissement dans la console si quelqu'un essaie d'utiliser ces événements sur le socket lui-même ? Je pense que ce serait très utile pour les personnes qui migrent, au lieu d'échouer en silence. 😄

Cette page vous a été utile?
0 / 5 - 0 notes