Il linguaggio JavaScript è ormai un requisito necessario per diventare uno sviluppatore web. Insieme ad HTML e CSS, rappresenta uno strumento chiave per la programmazione nativa (e non) di app web, prevalentemente lato frontend.
Imparare JavaScript programmando
Il modo migliore di imparare, si sa, è fare: in questo articolo vedremo, quindi, come creare da zero un two-way data binding in JavaScript. Prima di adoperarci nel concreto, però, è sempre utile spolverare un po’ di nozioni.
Che cos’è un two-way data binding?
Un two-way data binding si riferisce alla sincronizzazione dei dati tra il modello e la vista in entrambe le direzioni. Nel linguaggio Javascript, ed in particolare in Vanilla JavaScript, è possibile creare una semplice associazione dati bidirezionale utilizzando i listener di eventi e aggiornando il modello e la visualizzazione di conseguenza.
Programmare in JavaScript è il modo migliore per impararlo, osservando il codice e cimentandosi in esso. Per creare un two-way data binding, creeremo la proprietà di un oggetto con una funzione getter e un setter. Principalmente la funzione setter dell’oggetto per aggiornare il valore dell’elemento HTML corrispondente.
Tra le funzioni in JavaScript messe a disposizione utilizzeremo la Object.defineProperty per definire il getter e il setter per la proprietà di un oggetto.
Cimentiamoci con la programmazione JavaScript: creiamo un two-way data binding
1. const data = {}; Object.defineProperty(data, 'prop', { get: function () { console.log('Chiamata al Getter’); }, set: function (value) { console.log('Chiamata al Setter'); } });
Dopo aver creato un oggetto con funzioni getter e setter incominciamo con il two-way data binding. Aggiorneremo il seguente codice con nuovi semplici elementi HTML.
1. <input id="inputEl" type="text" /> 2. <span id="val"></span>
Quindi, il codice Javascript sarà:
const data = { 3. value: '' // a field to store the actual value 4. };Object.defineProperty(data, 'prop', { 5. get: function() { 6. console.log('Getter called'); 7. return this.value; 8. }, 9. set: function(value) { 10. console.log('Setter called'); 11. this.value = value; 12. printVal(); 13. } 14. }); 15. // attaching the event listener on keyup events 16. const el = document.getElementById('inputEl'); 17. el.addEventListener('keyup', (event) => { 18. data.prop = event.target.value; 19. });function printVal() { 20. const el = document.getElementById('val'); 21. el.innerText = data.prop; 22. }
In questo modo, la modifica del valore dell’elemento di input aggiorna il testo visualizzato nell’HTML. Ora, però, vogliamo anche l’altro lato: l’aggiornamento del valore dovrebbe aggiornare il valore dell’elemento HTML. Inseriremo un bottone che aggiornerà il valore nel tag input.
1. <input id="inputEl" placeholder="Enter a number..." type="text" /> 2. <span id="val"></span> 3. <button id="incrementVal">Increment</button>
Il codice Javascript sarà:
const data = { 4. value: '' 5. };const el = document.getElementById('inputEl');Object.defineProperty(data, 'prop', { 6. get: function() { 7. console.log('Getter called'); 8. return this.value; 9. }, 10. set: function(value) { 11. console.log('Setter called'); 12. this.value = value; 13. el.value = value; 14. printVal(); 15. } 16. });// attaching the event listener on keyup events 17. el.addEventListener('keyup', (event) => { 18. data.prop = event.target.value; 19. });function printVal() { 20. const el = document.getElementById('val'); 21. el.innerText = data.prop; 22. }const btn = document.getElementById('incrementVal'); 23. btn.addEventListener('click', () => { 24. data.prop = Number(data.prop) + 1; 25. });
Attraverso questo semplice codice JavaScript, avremo un elemento che si aggiorna automaticamente ogni volta che viene premuto il bottone collegato alla casella di input. In questo modo avremo creato un two-way data binding molto semplice da comprendere.
Non farti spaventare dalla sintassi JavaScript, nel mondo della programmazione informatica ciò che conta è comprendere la logica che c’è dietro ogni singola riga di codice, indipendentemente dal linguaggio in cui viene scritto. Imparare JavaScript ti può aiutare anche a comprendere logicamente cos’è la programmazione informatica. Prova a cimentarti con il linguaggio JavaScript leggendo la nostra guida Javascript in italiano!