Torna indietro   Hardware Upgrade Forum > Software > Programmazione

iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile
C'è tanta sostanza nel nuovo smartphone della Mela dedicato ai creator digitali. Nuovo telaio in alluminio, sistema di raffreddamento vapor chamber e tre fotocamere da 48 megapixel: non è un semplice smartphone, ma uno studio di produzione digitale on-the-go
Intel Panther Lake: i processori per i notebook del 2026
Intel Panther Lake: i processori per i notebook del 2026
Panther Lake è il nome in codice della prossima generazione di processori Intel Core Ultra, che vedremo al debutto da inizio 2026 nei notebook e nei sistemi desktop più compatti. Nuovi core, nuove GPU e soprattutto una struttura a tile che vede per la prima volta l'utilizzo della tecnologia produttiva Intel 18A: tanta potenza in più, ma senza perdere in efficienza
Intel Xeon 6+: è tempo di Clearwater Forest
Intel Xeon 6+: è tempo di Clearwater Forest
Intel ha annunciato la prossima generazione di processori Xeon dotati di E-Core, quelli per la massima efficienza energetica e densità di elaborazione. Grazie al processo produttivo Intel 18A, i core passano a un massimo di 288 per ogni socket, con aumento della potenza di calcolo e dell'efficienza complessiva.
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: 204
[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: 2776
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: 204
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: 2776
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: 204
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


iPhone 17 Pro: più di uno smartphone. È uno studio di produzione in formato tascabile iPhone 17 Pro: più di uno smartphone. &Eg...
Intel Panther Lake: i processori per i notebook del 2026 Intel Panther Lake: i processori per i notebook ...
Intel Xeon 6+: è tempo di Clearwater Forest Intel Xeon 6+: è tempo di Clearwater Fore...
4K a 160Hz o Full HD a 320Hz? Titan Army P2712V, a un prezzo molto basso 4K a 160Hz o Full HD a 320Hz? Titan Army P2712V,...
Recensione Google Pixel Watch 4: basta sollevarlo e si ha Gemini sempre al polso Recensione Google Pixel Watch 4: basta sollevarl...
TP-Link è già proiettata a...
Colpo grosso di Zuckerberg: Meta assume ...
Addio ai matrimoni con l'intelligenza ar...
Le sonde spaziali ESA ExoMars e Mars Exp...
Roscosmos: static fire per i propulsori ...
Alcune partite NBA saranno trasmesse in ...
Intel Core 13000 e 14000 aumentano uffic...
Gemini sta per arrivare in Google Maps: ...
2 minuti per vedere le 27 offerte imperd...
Ray-Ban Meta Display: tecnologia sorpren...
Un mini PC a prezzo stracciato, non cerc...
Al via i coupon nascosti di ottobre: qua...
Ferrari Elettrica si aggiorna solo in of...
Doppio sconto sugli smartphone top Xiaom...
Samsung è sempre più prota...
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: 07:41.


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