Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Roborock Qrevo Curv 2 Flow: ora lava con un rullo
Qrevo Curv 2 Flow è l'ultima novità di casa Roborock per la pulizia di casa: un robot completo, forte di un sistema di lavaggio dei pavimenti basato su rullo che si estende a seguire il profilo delle pareti abbinato ad un potente motore di aspirazione con doppia spazzola laterale
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite
Abbiamo guidato per diversi giorni la Alpine A290, la prima elettrica del nuovo corso della marca. Non è solo una Renault 5 sotto steroidi, ha una sua identità e vuole farsi guidare
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile
Abbiamo provato a fondo il nuovo Magic 8 Lite di HONOR, e per farlo siamo volati fino a Marrakech , dove abbiamo testato la resistenza di questo smartphone in ogni condizione possibile ed immaginabile. Il risultato? Uno smartphone praticamente indistruttibile e con un'autonomia davvero ottima. Ma c'è molto altro da sapere su Magic 8 Lite, ve lo raccontiamo in questa recensione completa.
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 02-08-2017, 21: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, 07:42   #2
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
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, 09: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, 16:04   #4
wingman87
Senior Member
 
Iscritto dal: Nov 2005
Messaggi: 2787
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, 16: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


Roborock Qrevo Curv 2 Flow: ora lava con un rullo Roborock Qrevo Curv 2 Flow: ora lava con un rull...
Alpine A290 alla prova: un'auto bella che ti fa innamorare, con qualche limite Alpine A290 alla prova: un'auto bella che ti fa ...
Recensione HONOR Magic 8 Lite: lo smartphone indistruttibile e instancabile Recensione HONOR Magic 8 Lite: lo smartphone ind...
Sony WF-1000X M6: le cuffie in-ear di riferimento migliorano ancora Sony WF-1000X M6: le cuffie in-ear di riferiment...
Snowflake porta l'IA dove sono i dati, anche grazie a un accordo con OpenAI Snowflake porta l'IA dove sono i dati, anche gra...
AOC propone un QD-OLED al prezzo di un I...
AGCOM segnalerà la AI Mode di Goo...
L'Estonia porta ChatGPT in classe: firma...
2 nm giapponesi contro TSMC: il piano di...
Questa scopa elettrica Tineco iFLOOR 5 è...
FRITZ!Box 6825 4G sbarca in Italia a 129...
Red Hat presenta Digital Sovereignty Rea...
AMD Zen 6 'Olympic Ridge': sette configu...
Amazon batte Walmart dopo 30 anni: il so...
Digos nel mirino dell'intelligence cines...
Sony non vuole aumentare il prezzo della...
Energia geotermica: la (costosa) rispost...
MG ha già venduto 1 milione di au...
"Something Big Is Happening" —...
Renault chiude il 2025 con una perdita r...
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: 22:14.


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