Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA
Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA
Abbiamo partecipato ad Appian World 2024, evento dedicato a partner e clienti che si è svolto recentemente nei pressi di Washington DC, vicino alla sede storica dell’azienda. Nel festeggiare il 25mo anniversario, Appian ha annunciato diverse novità in ambito intelligenza artificiale
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini
Primo contatto con il monitor Lenovo ThinkVision 3D 27 che grazie a particolari accorgimenti tecnici riesce a ricreare l'illusione della spazialità tridimensionale senza che sia necessario utilizzare occhialini
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing
Abbiamo visto ancora una volta la Formula E da vicino, ospiti di Jaguar TCS Racing. In questa occasione però curve e rettilinei erano quelli di un circuito permanente, molto diverso dagli stretti passaggi delle strade di Roma
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-08-2017, 20:32   #1
Axel.vv
Member
 
Iscritto dal: Sep 2014
Messaggi: 202
[Javascript] Documentazione sugli eventi nei browser

Ciao a tutti,
Ammetto di non essere un gran programmatore, ma me la sono sempre cavata con piccole applicazioni nei linguaggi più comuni. Ora però mi sto perdendo in un bicchiere d'acqua con gli eventi in Javascript. Non tanto se si tratta di eseguire una funzione a seguito di un evento, quanto piuttosto padroneggiare eventi legati alle operazioni asincrone, come la lettura di un file, Ajax, web workers etc.
C'è sempre un oggetto "e" o "ev", negli esempi, ma non capisco a fondo il meccanismo che genera tale oggetto. Così mi trovo a rimaneggiare codice scovato su internet, senza sapere esattamente come funzioni, e la cosa non mi fa impazzire.
Qualcuno saprebbe indicarmi dove trovare della documentazione esaustiva sull'argomento? Inglese o italiano è indifferente, solo, vorrei si trattasse di Javascript puro, no JQuery o altre librerie.
Grazie mille!
Axel.vv è offline   Rispondi citando il messaggio o parte di esso
Old 03-08-2017, 06:42   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2745
Ti consiglio Mdn: https://developer.mozilla.org/en-US/docs/Web/API/Event

In genere in fondo ad ogni pagina c'è anche un riferimento alle specifiche (che consulto di rado perché in genere le informazioni su Mdn sono più che sufficienti)

Inviato dal mio F5121 utilizzando Tapatalk
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-08-2017, 08:00   #3
Axel.vv
Member
 
Iscritto dal: Sep 2014
Messaggi: 202
Quote:
Originariamente inviato da wingman87 Guarda i messaggi
Grazie mille wingman87, solitamente bazzico più w3schools, ma conosco anche MDN. Purtroppo non ho mai trovato l'informazione che cerco, che può essere riassunta in questi due esempi di codice:

Codice:
w = new Worker("demo_workers.js");
w.onmessage = function(event){
    document.getElementById("result").innerHTML = event.data;
};
e
Codice:
var reader = new FileReader();
reader.onload = function(event) {
    var testo = event.target.result;
    document.getElementById("contenuto").innerHTML = testo;
};
reader.readAsText(file);
Non capisco il pattern oggetto.evento = funzione (event) {...}
In particolare "event", da dove arriva? chi lo inizializza?

Sono certo sia una stupidata, ma proprio non ci arrivo .
Grazie!!
Axel.vv è offline   Rispondi citando il messaggio o parte di esso
Old 03-08-2017, 15:04   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2745
Quote:
Originariamente inviato da Axel.vv Guarda i messaggi
Grazie mille wingman87, solitamente bazzico più w3schools, ma conosco anche MDN. Purtroppo non ho mai trovato l'informazione che cerco
...
...
Non capisco il pattern oggetto.evento = funzione (event) {...}
In particolare "event", da dove arriva? chi lo inizializza?
Il pattern è legato all'event loop
https://developer.mozilla.org/en-US/...ript/EventLoop

Sostanzialmente se i dati che ti servono non sono immediatamente disponibili, come succede quando devi attendere un certo messaggio o devi leggere un file, allora si registra un handler per l'evento per non bloccare l'applicazione. E' un'operazione asincrona. L'handler è una funzione che prende un certo numero di parametri e il numero e il tipo dei parametri è dipendente dalle specifiche dell'evento. I parametri in alcuni casi ti verranno passati direttamente dal browser, altre volte da altri script.

Riguardo agli esempi che hai riportato:
Codice:
w = new Worker("demo_workers.js");
w.onmessage = function(event){
    document.getElementById("result").innerHTML = event.data;
};
Se guardi la documentazione di Worker.onmessage
https://developer.mozilla.org/en-US/...rker/onmessage
dice che è un event handler per eventi di tipo MessageEvent
https://developer.mozilla.org/en-US/...I/MessageEvent
che tra le varie proprietà ha anche "data"

Codice:
var reader = new FileReader();
reader.onload = function(event) {
    var testo = event.target.result;
    document.getElementById("contenuto").innerHTML = testo;
};
reader.readAsText(file);
FileReader è un po' più complicato.
Nella pagina di FileReader.onload
https://developer.mozilla.org/en-US/...eReader/onload
dice che onload è l'handler che viene eseguito quando viene sollevato l'evento load
https://developer.mozilla.org/en-US/...eb/Events/load
come vedi quest'evento ha la proprietà target che punta a un EventTarget. FileReader implementa EventTarget (lo vedi nella colonna di sinistra della pagina di FileReader), quindi con event.target stai puntando al FileReader e con event.target.result stai leggendo la proprietà result del FileReader
https://developer.mozilla.org/en-US/...eReader/result
wingman87 è offline   Rispondi citando il messaggio o parte di esso
Old 03-08-2017, 15:55   #5
Axel.vv
Member
 
Iscritto dal: Sep 2014
Messaggi: 202
Grazie mille, Davvero!
Il tassello che mi mancava era l'Event Loop.
Ora è tutto molto più chiaro!
Axel.vv è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Appian: non solo low code. La missione è l’ottimizzazione dei processi con l'IA Appian: non solo low code. La missione è ...
Lenovo ThinkVision 3D 27, la steroscopia senza occhialini Lenovo ThinkVision 3D 27, la steroscopia senza o...
La Formula E può correre su un tracciato vero? Reportage da Misano con Jaguar TCS Racing La Formula E può correre su un tracciato ...
Lenovo LEGION e LOQ: due notebook diversi, stessa anima gaming Lenovo LEGION e LOQ: due notebook diversi, stess...
Nothing Ear e Ear (a): gli auricolari per tutti i gusti! La ''doppia'' recensione Nothing Ear e Ear (a): gli auricolari per tutti ...
Il 5 maggio torna la Maratona Fotografic...
Teatro dei Vitellini - Regia di Gian Pao...
Phi-3 Mini, il modello IA di Microsoft c...
D-Wave annuncia la disponibilità ...
AWS aggiorna Amazon Bedrock con nuove fu...
Sonos: in arrivo un restyling completo p...
La Russia ha condannato il direttore del...
Dead Island 2 arriva finalmente su Steam...
Era già il tablet più conv...
Razer Viper V3 Pro: il mouse da gaming w...
Noctua NH-L12Sx77: il dissipatore per bu...
AVM FRITZ!Repeater 1200 AX: il più vendu...
Apple presenterà i nuovi iPad il ...
SAP introduce l'IA nelle sue soluzioni p...
OnePlus lancia in Europa il nuovo Watch ...
Chromium
GPU-Z
OCCT
LibreOffice Portable
Opera One Portable
Opera One 106
CCleaner Portable
CCleaner Standard
Cpu-Z
Driver NVIDIA GeForce 546.65 WHQL
SmartFTP
Trillian
Google Chrome Portable
Google Chrome 120
VirtualBox
Tutti gli articoli Tutte le news Tutti i download

Strumenti

Regole
Non Puoi aprire nuove discussioni
Non Puoi rispondere ai messaggi
Non Puoi allegare file
Non Puoi modificare i tuoi messaggi

Il codice vB è On
Le Faccine sono On
Il codice [IMG] è On
Il codice HTML è Off
Vai al Forum


Tutti gli orari sono GMT +1. Ora sono le: 20:12.


Powered by vBulletin® Version 3.6.4
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd.
Served by www3v