Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Polestar 3 Performance, test drive: comodità e potenza possono convivere
Polestar 3 Performance, test drive: comodità e potenza possono convivere
Abbiamo passato diversi giorni alla guida di Polestar 3, usata in tutti i contesti. Come auto di tutti i giorni è comodissima, ma se si libera tutta la potenza è stupefacente
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026
In occasione del proprio Architecture Deep Dive 2025 Qualcomm ha mostrato in dettaglio l'architettura della propria prossima generazione di SoC destinati ai notebook Windows for ARM di prossima generazione. Snapdragon X2 Elite si candida, con sistemi in commercio nella prima metà del 2026, a portare nuove soluzioni nel mondo dei notebook sottili con grande autonomia
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice
DJI Mini 5 Pro porta nella serie Mini il primo sensore CMOS da 1 pollice, unendo qualità d'immagine professionale alla portabilità estrema tipica di tutti i prodotti della famiglia. È un drone C0, quindi in un peso estremamente contenuto e che non richiede patentino, propone un gimbal rotabile a 225 gradi, rilevamento ostacoli anche notturno e autonomia fino a 36 minuti. Caratteristiche che rendono il nuovo drone un riferimento per creator e appassionati
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


Polestar 3 Performance, test drive: comodità e potenza possono convivere Polestar 3 Performance, test drive: comodit&agra...
Qualcomm Snapdragon X2 Elite: l'architettura del SoC per i notebook del 2026 Qualcomm Snapdragon X2 Elite: l'architettura del...
Recensione DJI Mini 5 Pro: il drone C0 ultra-leggero con sensore da 1 pollice Recensione DJI Mini 5 Pro: il drone C0 ultra-leg...
ASUS Expertbook PM3: il notebook robusto per le aziende ASUS Expertbook PM3: il notebook robusto per le ...
Test ride con Gowow Ori: elettrico e off-road vanno incredibilmente d'accordo Test ride con Gowow Ori: elettrico e off-road va...
Grazie a VLT è stata misurata dir...
Blue Origin annuncia un aerofreno ripieg...
Blue Origin annuncia una nuova versione ...
LG UltraFine evo 6K: il primo monitor al...
DJI cambia direzione: investe in Elegoo ...
Black Friday Narwal 2025: risparmi da ca...
Phishing evoluto contro Apple ID: caso f...
Prestazioni in discesa nei giochi? NVIDI...
Addio ai banner dei cookie? L'UE spinge ...
Le offerte Black Friday per gli smartpho...
Il controllo qualità degli iPhone...
Qualcomm Snapdragon X Elite vola con il ...
A2RL Season 2: storia, innovazione e sor...
Core Ultra Series 3: Intel conferma l'ev...
Black Friday Amazon: la GeForce RTX 5070...
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: 07:39.


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