Sono un principiante del nodo e sto provando a impostare un caricamento di immagini multifile attraverso formidabile che avrà una barra di avanzamento e anche una richiamata dopo ogni upload che sarà dinamicamente carica tutte le immagini nella stessa pagina dopo averle caricate. Capisco che ho bisogno di usare socket.io per interagire con il browser dopo che il caricamento è iniziato. Formidable ha un listener di eventi per "progresso". Ho bisogno del mio script lato client per ricevere i byte ricevuti per creare una barra di caricamento. Dopo il caricamento del file, voglio che socket.io passi al client l'url di dove è stata caricata l'immagine in modo che il client possa caricare l'immagine e aggiungerla dinamicamente al DOM. Ecco il codice che ho finora.Come connettere il formidable file upload a socket.io in Node.js
La mia domanda è: come faccio a strutturare il codice socket.io all'interno del listener di eventi per "avanzamento" in modo che possa trasmettere al client?
Ecco alcuni pseudo-codice sciolto per mostrare che cosa sto parlando:
//formidable code:
app.post('/new', function(req,res){
var form = new formidable.IncomingForm();
form.addListener('progress', function(bytesReceived, bytesExpected){
//Socket.io interaction here??
});
form.uploadDir = __dirname + '/public/images/';
form.on('file', function(field, file) {
//rename the incoming file to the file's name
fs.rename(file.path, form.uploadDir + "/" + file.name);
console.log(form.uploadDir + "/" + file.name);
})
});
//socket.io code
io.sockets.on('connection', function (socket) {
socket.on('upload', function (msg) {
socket.broadcast.emit('progress', bytesReceived);
});
});
Alcuni progressi. Il modo di trasmettere al client socket.io è 'io.sockets.emit ('byte', byteRicevuto)' – mistersoftee