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 10-02-2010, 00:40   #1
Tadde
Senior Member
 
Iscritto dal: Oct 2001
Città: Firenze
Messaggi: 585
[XHTML]Carriage return nell'editor diventa spazio per il browser

Mi sono trovato di fronte a un problema inaspettato.
Questo semplice pezzo di codice:

Codice:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
 <head>
 <script type="text/javascript">
  function checkLen(x) {
   if (x.value.length === x.maxLength)
    x.nextSibling.focus();
  }
 </script>
 </head>

<body>
<p>Salta al campo successivo quando raggiungo la maxlength di quello attuale:</p>

 <form id="myForm">
  <input size="3" maxlength="3" onkeyup="checkLen(this)" />
  <input size="2" maxlength="2" onkeyup="checkLen(this)" />
  <input size="3" maxlength="3" onkeyup="checkLen(this)" />
 </form>
</body>

</html>
non funziona come dovrebbe se viene copiato e incollato così com'è e aperto con un browser.
Il problema sta nel fatto che dopo ogni tag <input> io sono andato a capo col tasto invio, e questo carattere speciale viene considerato dal browser come uno spazio.

Quindi quando nel codice Javascript indirizzo il nextSibling dell'elemento che chiama la funzione, questo elemento indirizzato non è il seguente tag <input> come vorrei ma lo spazio tra i due.

Se provate a togliere i ritorni a capo tra i tag invece funzionerà come voluto.
Ho provato a salvare il documento con i ritorni a capo in vari formati (ANSI, UTF-8, ecc...), ma non cambia nulla.

Io alla leggibilità di un codice coi ritorni a capo al punto giusto non vorrei rinunciare, invece vorrei rinunciare alle trappole come quella in cui mi sono imbattuto stasera .

Conoscete qualche fix o stratagemma per risolvere il problema, cioè per poter scrivere codice senza doversi preoccupare di questo comportamento dei browser (pare sia un comportamento comune a tutti o quasi i browser)?
Tadde è offline   Rispondi citando il messaggio o parte di esso
Old 10-02-2010, 09:13   #2
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
http://www.w3.org/DOM/faq.html#emptytext
https://developer.mozilla.org/En/DOM/Node.nextSibling

dovresti controllare se il nodeType è 3 (testo) e in tal caso passare al nodo successivo.
Se non ricordo male ie non inserisce nel dom gli spazi vuoti mentre firefox si.
tomminno è offline   Rispondi citando il messaggio o parte di esso
Old 10-02-2010, 12:19   #3
CozzaAmara
Senior Member
 
L'Avatar di CozzaAmara
 
Iscritto dal: Nov 2008
Messaggi: 411
Prova magari la cosa con i metodi del DOM di un framework come JQuery, ora non ricordo, ma è possibile che ti risolva in modo "trasparente" il problema verificando a priori di che "tipo" di nodo si tratta come indicato anche da tomminno.
__________________
CozzaAmara è offline   Rispondi citando il messaggio o parte di esso
Old 10-02-2010, 18:25   #4
Tadde
Senior Member
 
Iscritto dal: Oct 2001
Città: Firenze
Messaggi: 585
Grazie per le risposte.

@tommino
Questo senz'altro risolverebbe nel mio specifico caso, ma non senti anche tu il bisogno di usare metodologie che si svincolino dagli if che trattano i casi specifici? Sto cercando regole per scrivere codice una volta sola senza doverlo testare su più di una piattaforma, risparmiandomi brutte sorprese e soprattutto tempo; questo renderebbe il mio lavoro molto più produttivo.
La richiesta che avevo fatto nel mio post di apertura temo dovrà rimanere insoddisfatta dato che se un editor non infilasse un simbolo per codificare il ritorno a capo, allora alla successiva riapertura del file da parte dell'editor ovviamente perderei la formattazione.
L'unica soluzione sarebbe quella di mettere codice senza alcuna formattazione in un file, e tutta l'informazione relativa alla formattazione in un altro. Ovviamente il documento finale html sarebbe solo il primo.
Una specie di file documento + file metadati relativi... forse coi prossimi filesystem ibridi tra filesystem tradizionali e DB questo sarà possibile.

Per ora mi limito a ricordarmi di usare nextSibling il meno possibile e anzi indirizzare elementi con altre strade che il DOM mi mette a disposizione.

@CozzaAmara
Sì, probabilmente tra un po' di tempo, quando avrò ritenuto sufficiente l'esperienza con JS "nudo", seguirò il tuo consiglio.
Tadde è offline   Rispondi citando il messaggio o parte di esso
Old 10-02-2010, 20:55   #5
tomminno
Senior Member
 
Iscritto dal: Oct 2005
Messaggi: 3306
Quote:
Originariamente inviato da Tadde Guarda i messaggi
Grazie per le risposte.

@tommino
Questo senz'altro risolverebbe nel mio specifico caso, ma non senti anche tu il bisogno di usare metodologie che si svincolino dagli if che trattano i casi specifici?
Da qualche parte quell'if lo dovrai mettere dato che non puoi modificare il dom parser fornito con il browser (e anche potendo, modificare il parser solo per evitare un brutto if mi sembra assurdo)

Quote:
Sto cercando regole per scrivere codice una volta sola senza doverlo testare su più di una piattaforma,
In ambito web? Impossibile.

Quote:
risparmiandomi brutte sorprese e soprattutto tempo; questo renderebbe il mio lavoro molto più produttivo.
Se ci fosse un unico standard (sia per l'html sia per i javascript) a cui tutti i browser aderissero strettamente e alla stessa maniera (perchè magari tutti sono aderenti allo standard ma ognuno lo è a modo suo) il tuo ragionamento avrebbe un senso, ma dato che non è così la tua mi sembra una utopia.

Quote:
La richiesta che avevo fatto nel mio post di apertura temo dovrà rimanere insoddisfatta dato che se un editor non infilasse un simbolo per codificare il ritorno a capo, allora alla successiva riapertura del file da parte dell'editor ovviamente perderei la formattazione.
Eh? Il tuo problema non è dovuto all'editor ma alle differenze tra browser. Per cui con quell'if tendi a rimuovere le differenze sia di scrittura dell'html (potrei mettere nel testo decine di a capo) sia di browser.

Quote:
L'unica soluzione sarebbe quella di mettere codice senza alcuna formattazione in un file, e tutta l'informazione relativa alla formattazione in un altro. Ovviamente il documento finale html sarebbe solo il primo.
Una specie di file documento + file metadati relativi... forse coi prossimi filesystem ibridi tra filesystem tradizionali e DB questo sarà possibile.
Tutto questo per evitare un banalissimo if?

Ciao
Tommaso
tomminno è 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: 02:27.


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