Una menzione particolare la merita l'operatore di negazione(indicato con !), che serve a negare un'espressione. Si tratta di un operatore unario: viene infatti posto di fronte all'espressione da negare, senza essere confrontato con nient'altro.
Utilizzando l'operatore di diversità nel giusto modo possiamo scrivere:
La sintassi è la seguente:
if ( ! (espressione) ) {
//istruzioni
}
che significa:
Ad esempio:
x = 7;
if (! (x == 7) ) {
alert ("x non è 7");
}
Ovviamente l'esempio che abbiamo appena esaminato non è di particolare utilità e in questo caso non c'è una grossa differenza rispetto all'utilizzo dell'operatore di diversità (!=) che abbiamo visto nelle lezioni precedenti:
x = 7;
if (x! = 7) {
alert ("x non è 7");
}
Ma se teniamo conto che possiamo utilizzare gli operatori logici per creare situazioni molto complesse, combinando fra loro le varie espressioni, allora appare evidente come l'utilizzo del not sia particolarmente utile. Ad esempio:
nome="Gianni";
if ( ! ( (nome == "Gianni") || (nome == "Marco") ) ) {
alert ("Non sei né Gianni, né Marco");
}
Abbiamo accennato nella lezione precedente agli "operatori a livello di bit". Nella programmazione JavaScript non li userete quasi mai, ma è bene sapere che esistono. Perché se per errore scrivete:
(x >= 5) & (x <= 7)
in realtà state utilizzando un operatore a livello di bit e non un operatore logico.
La differenza sta nel fatto che gli operatore di bit convertono tutte le espressioni in valori binari, prima di eseguire i confronti, e poi li confrontano bit a bit. Dal momento che - a volte - ciò comporta delle approssimazioni, la valutazione delle espressioni può non dare adito allo stesso risultato rispetto agli operatori logici.
|
Vediamo un esempio in cui operatori logici e operatori a livello di bit danno adito a risultati differenti. Nell'esempio seguente l'operatore logico restituisce un risultato corretto:
if ( (document.all) && (navigator.platform.indexOf("Win")>-1) ) {
alert ("Stai usando Internet Explorer su Windows");
} else {
alert ("Stai usando Internet Explorer su Mac");
}
/* L'oggetto navigator.platform contiene le indicazioni sul
sistema operativo che l'utente sta usando. Nel caso di
Windows: alert(navigator.platform); restituisce "Win32"
indexOf serve per cercare del testo in una stringa: se
non lo trova restituisce "-1", ecco perché abbiamo chiesto
di verificare che il risultato di indexOf sia maggiore
di -1. In pratica così facendo abbiamo chiesto di verificare
che navigator.platform contenga "Win".
*/
Utilizzando l'operatore a livello di bit invece il risultato dello script non è corretto:
if ( (document.all) & (navigator.platform.indexOf("Win")!=-1) ) {
alert ("Stai usando Internet Explorer su Windows");
} else {
alert ("Stai usando Internet Explorer su Mac");
}
PhantomJS, headless browser per test con JavascriptIl tool ideale per realizzare, da terminale, operazioni in remoto su... |
Creare e leggere QR Code in JavaScriptApplicazioni 'QR Code enabled' per il Web e per il mobile,... |
Jquery UI Map: web-mapping con Google Maps e jQueryUn plugin di jQuery UI per intefacciare applicaizoni Web/mobile con... |
Scrollorama e Scrolldeck, slideshow d'effetto con jQueryPlugin jQuery per ottenere Slideshow con diversi effetti di scrolling |
jCanvas, un primo semplice graficoAlla scoperta della libreria jCanvas, per semplificare il disegno e... |
Guida Node.jsIl framework che permette di per usare V8, l'interprete JavaScript... |
Canvas, guida ai frameworkCanvas, tra gli elementi di HTML5 è forse quello di maggior impatto.... |
Guida Javascript: tecniche avanzateUna guida dal taglio pratico per approfondire la programmazione a... |
Ogni martedì, direttamente nella tua e-mail: guide, articoli, script, novità e approfondimenti tecnici su JavaScript.
Iscriviti alla newsletter
|
|
Corso Webmaster base18 Giugno 2012 a Milano |
|
|
Corso Google AdWords Base25 Giugno 2012 a Milano |
|
|
Corso JQuery e Ajax per Webmaster03 Luglio 2012 a Milano |
|
|
Corso Google AdWords Base05 Giugno 2012 a Roma |
|
|
Corso Webmaster base11 Giugno 2012 a Roma |