Errori con le unità di misura in JavaScript
Spesso è facile sbagliare e dimenticarsi delle unità di misura. Ad esempio, così:
let width = 100;
elem.style.width = width; // ops...
Correttamente si dovrebbe specificare il valore in pixel:
let width = 100;
elem.style.width = width + 'px';
Immaginiamo di voler aumentare
la larghezza di un certo valore. Per farlo
dobbiamo prima leggere la larghezza,
poi estrarre il numero, aggiungergli
il valore desiderato, aggiungere 'px'
e solo allora riscriverlo:
let widthPx = elem.style.width;
let widthNm = parseInt(widthPx);
elem.style.width = (widthNm + 30) + 'px';
Spiegate qual è l'errore nel seguente codice:
<div style="font-size: 16px;">
text
</div>
let elem = document.querySelector('div');
elem.style.fontSize = elem.style.fontSize + 2;
Spiegate qual è l'errore nel seguente codice:
<div style="font-size: 16px;">
text
</div>
let elem = document.querySelector('div');
elem.style.fontSize = parseInt(elem.style.fontSize + 2) + 'px';
Spiegate qual è l'errore nel seguente codice:
<div style="font-size: 2.5em;">
text
</div>
let elem = document.querySelector('div');
elem.style.fontSize = parseInt(elem.style.fontSize) + 2 + 'em';
Dato il div:
<div id="elem" style="width: 300px; height: 200px; border: 1px solid red;">
text
</div>
Data anche un pulsante. Al click sul pulsante
aumentate la larghezza e l'altezza del div di
50px.
Dato il div:
<div id="elem" style="width: 300px; height: 200px; border: 1px solid red;">
text
</div>
Data anche un pulsante. Al click sul pulsante
aumentate la larghezza e l'altezza del div di
10%.