Torna indietro   Hardware Upgrade Forum > Software > Programmazione

Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto
Xiaomi ha portato sul mercato internazionale la nuova serie Redmi Note, che rappresenta spesso una delle migliori scelte per chi non vuole spendere molto. Il modello 15 Pro+ punta tutto su una batteria capiente e su un ampio display luminoso, sacrificando qualcosa in termini di potenza bruta e velocità di ricarica
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione
HONOR ha finalmente lanciato il suo nuovo flagship: Magic 8 Pro. Lo abbiamo provato a fondo in queste settimane e ve lo raccontiamo nella nostra recensione completa. HONOR rimane fedele alle linee della versione precedente, aggiungendo però un nuovo tasto dedicato all'AI. Ma è al suo interno che c'è la vera rivoluzione grazie al nuovo Snapdragon 8 Elite Gen 5 e alla nuova MagicOS 10
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata
Le webcam Insta360 Link 2 Pro e Link 2C Pro sono una proposta di fascia alta per chi cerca qualità 4K e tracciamento automatico del soggetto senza ricorrere a configurazioni complesse. Entrambi i modelli condividono sensore, ottiche e funzionalità audio avanzate, differenziandosi per il sistema di tracciamento: gimbal a due assi sul modello Link 2 Pro, soluzione digitale sul 2C Pro
Tutti gli articoli Tutte le news

Vai al Forum
Rispondi
 
Strumenti
Old 09-09-2009, 12:19   #1
Abdujaparov
Senior Member
 
Iscritto dal: Aug 2004
Città: Palermo
Messaggi: 1079
[Javascript] Figli di un elemento

Ciao a tutti,
ho un piccolo problema con javascript. Ho una pagina con più form quando presso un tasto viene richiamata una funzione javascript che scorre i form e man mano passa il form ad un'altra funzione che ne valida alcuni campi.
Il mio problema è come far prendere, alla seconda funzione i nodi figli del form, in particolare gli input text.
Ho scritto le seguenti due funzioni:
Codice:
function valida(){
   
    var forms = document.getElementsByTagName("form");
    
    
    for(i=0; i<forms.length; i++){

      checkValida(forms[i].childNodes);
    }
   
   }

function checkValida(form){
    
      var patternNumerico = /^[0-9]+(\.[0-9]*)?$/;
      
      var navInput = form.getElementsByTagName("input");
      
      for(i=0; i<navInput.length; i++){
        if(navInput[i].type=="text"){
          if(navInput[i].value.length>0 && !patternNumerico.test(navInput[i].value))
            alert('Campo NAV non valido');
            return false;
          }
      }
   
        return true; 
   }
Il problema lo incontro alla riga:
Codice:
var navInput = form.getElementsByTagName("input");
Il form contiene una tabella, che ha al suo interno varie righe e varie colonne.
In una colonna sono contenuti degli elementi input di tipo text, che sono quelli che mi interessano.
Come faccio a prenderli?
Grazie a tutti, ciao ciao.
Abdujaparov è offline   Rispondi citando il messaggio o parte di esso
Old 09-09-2009, 13:02   #2
Y3PP4
Member
 
Iscritto dal: Jul 2009
Messaggi: 210
Quote:
Originariamente inviato da Abdujaparov Guarda i messaggi
Ciao a tutti,
ho un piccolo problema con javascript. Ho una pagina con più form quando presso un tasto viene richiamata una funzione javascript che scorre i form e man mano passa il form ad un'altra funzione che ne valida alcuni campi.
Il mio problema è come far prendere, alla seconda funzione i nodi figli del form, in particolare gli input text.
Ho scritto le seguenti due funzioni:
Codice:
function valida(){
   
    var forms = document.getElementsByTagName("form");
    
    
    for(i=0; i<forms.length; i++){

      checkValida(forms[i].childNodes);
    }
   
   }

function checkValida(form){
    
      var patternNumerico = /^[0-9]+(\.[0-9]*)?$/;
      
      var navInput = form.getElementsByTagName("input");
      
      for(i=0; i<navInput.length; i++){
        if(navInput[i].type=="text"){
          if(navInput[i].value.length>0 && !patternNumerico.test(navInput[i].value))
            alert('Campo NAV non valido');
            return false;
          }
      }
   
        return true; 
   }
Il problema lo incontro alla riga:
Codice:
var navInput = form.getElementsByTagName("input");
Il form contiene una tabella, che ha al suo interno varie righe e varie colonne.
In una colonna sono contenuti degli elementi input di tipo text, che sono quelli che mi interessano.
Come faccio a prenderli?
Grazie a tutti, ciao ciao.
Se intendi prendere il valore dei textfield, basta accedere alla proprietà value dell'oggetto: document.form.textfield.value .

Se al form dichiari l'attributo name puoi accedere allo stesso senza doverlo catturare con getElementById:

Codice HTML:
<form name="modulo">
    <input type="text" name="miotesto">
    <!-- ... etc etc ... -->
Ci accedi facendo semplicemente:
Codice HTML:
document.modulo.miotesto
avendone ora il riferimento basta accedere alla proprietà value (document.modulo.miotesto.value) e potrai lavorare sul valore, ovvero sul testo inserito.

Ciao!

PS. aggiungo che in Javascript quasi sempre si usa il tag name per accedere direttamente alle proprietà dell'orggeto come ti ho illustrato sopra, per ovvia comodità.
__________________
La disumanità del computer sta nel fatto che, una volta programmato e messo in funzione, si comporta in maniera perfettamente onesta.
Isaac Asimov
Y3PP4 è offline   Rispondi citando il messaggio o parte di esso
 Rispondi


Redmi Note 15 Pro+ 5G: autonomia monstre e display luminoso, ma il prezzo è alto Redmi Note 15 Pro+ 5G: autonomia monstre e displ...
HONOR Magic 8 Pro: ecco il primo TOP del 2026! La recensione HONOR Magic 8 Pro: ecco il primo TOP del 2026! L...
Insta360 Link 2 Pro e 2C Pro: le webcam 4K che ti seguono, anche con gimbal integrata Insta360 Link 2 Pro e 2C Pro: le webcam 4K che t...
Motorola edge 70: lo smartphone ultrasottile che non rinuncia a batteria e concretezza Motorola edge 70: lo smartphone ultrasottile che...
Display, mini PC, periferiche e networking: le novità ASUS al CES 2026 Display, mini PC, periferiche e networking: le n...
La nave elettrica più grande mai ...
Spusu lancia il Wi-Fi Calling: come funz...
Questo robot impara a muovere le labbra ...
iPhone 17 annienta la concorrenza in Cin...
La nuova Xiaomi SU7 batte un record: 4.2...
È possibile copiare i qubit: dei ...
BYD alza ulteriormente l'asticella: batt...
Il nuovo razzo spaziale riutilizzabile c...
L'ex leader di Assassin's Creed porta Ub...
Il razzo spaziale NASA SLS e la capsula ...
Samsung Galaxy S26 Ultra: quattro colora...
AWS investe 1,2 miliardi in Italia. Coin...
La navicella cinese Shenzhou-20 con il f...
I piani Business ed Education di Google ...
Ceres-2 e Lunga Marcia 3B: la Cina falli...
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: 22:35.


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