Pomoc - Szukaj - Użytkownicy - Kalendarz
Pełna wersja: TEXT - ile ich jest?
Forum PHP.pl > Forum > Po stronie przeglądarki > JavaScript
MP1
Powiedzmy, że będą np. 3 pola TEXT o atrybucie NAME rozpoczynającym się na "cos", np. "cos1".

Jak teraz sprawdzić, ile jest takich pól TEXT:?
DeyV
a nie można zrobić
  1. <input type="text" name="test[1]">
  2. <input type="text" name="test[2]">

questionmark.gif
Chewolf
jesli potem dane z formularza przechodza do php to dane te masz w tablicy a tablice mozesz policzyc funkcja count...
zYm3N
ogólny zarys

  1. <?php
  2.  
  3. $ile = 0;
  4. foreach($_POST as $key => $val)
  5.  if (substr($key, 0, 3)=='cos')
  6. $ile+=1;
  7.  
  8. ?>


tylko zarys :-) Mogą być błędy :]
MP1
Dane nie przechodzą do php... Wszystko po stronie przeglądarki. Jest w JS funkcja do obliczenia, ile jest tych tablic (jak podał DeyV)?
Paul
  1. <input type="text" name="txt[]">
  2. <input type="text" name="txt[]">
  3. <input type="text" name="txt[]">
  4. <input type="button" value="Ile?" onclick="alert(this.form.elements['txt[]'].length);">
  5. </form>
  6. </body>
MP1
Zrobiłem tak (zgodne z przeglądarkami):
  1. alert(document.getElementById('odp').length);

Wyskakuje błąd: "Wymagany jest obiekt".
Paul
Kod
<html>
<head>
<script type="text/javascript">
function ile( ajdi ) {
   inputs = document.getElementsByTagName('input');
   for(i = 0, ilosc = 0; i < inputs.length; i++) {
      if(inputs[ i ].id.indexOf(ajdi) == 0 && inputs[ i ].type == 'text') {
         ilosc++;
      }
   }
   return ilosc;
}
</script>
</head>
<body>
<form>
<input type="text" id="cos1">
<input type="text" id="cos2">
<input type="text" id="cos3">
<input type="radio" id="cos4">
<input type="button" value="Ile?" onclick="alert(ile('cos'));">
</form>
</body>
</html>
MP1
Ten skrypt obliczy, ile jest wogóle znaczników INPUT. Mi chodzi o pola, które mają ID "odp" z odpowiednią tablicą, np. "odp[0]".

Na pewno musi być coś do obliczania tablic.

Znacie jakieś porządne kursy JS?
Paul
Cytat(http://www.w3.org/TR/REC-html40/struct/global.html#adef-id)
id = name [CS]
This attribute assigns a name to an element. This name must be unique in a document.

Ja to rozumiem tak, ze ID moze byc tylko jedno w danym dokumencie, a JS, zeby interpretowac to jako tablice potrzebowal by kilku takich samych ID, analogicznie jak w przypadku name.

Cytat(MP1)
Ten skrypt obliczy, ile jest wogóle znaczników INPUT. Mi chodzi o pola, które mają ID "odp" z odpowiednią tablicą, np. "odp[0]".

Ten skrypt oblicza ilosc pol TEXT ktorych ID zaczyna sie na wartosc podana w argumencie. Tak wiec w takim przypadku - odp[0] tez bedzie dzialac.

Skopiuj sobie ten skrypt i zamien tamte inputy na to - mi sie wydaje, ze dziala..
  1. <input type="text" id="cos[0]">
  2. <input type="text" id="cos[1]">
  3. <input type="text" id="cos[2]">
MP1
Kod
function Dodaj() {
  todpusr=document.getElementsByTagName('input');
  ileusr=0; for(i=0;i<todpusr.length;i++) {
    if(todpusr[i].id.indexOf('wys_pyt')==0 && todpusr[i].type=='text') {
  ileusr++; } }
  alert(ileusr); }

Wychodzi 0. Czy nie zrobiłem błędów?
Paul
Wyglada na to, ze nie. Taki kod zwraca 4, czyli prawidlowo.
  1. <script type="text/javascript">
  2. function Dodaj() {
  3. todpusr=document.getElementsByTagName('input');
  4. ileusr=0; for(i=0;i<todpusr.length;i++) {
  5. if(todpusr[i].id.indexOf('wys_pyt')==0 && todpusr[i].type=='text') {
  6. ileusr++; } }
  7. alert(ileusr); }
  8. </head>
  9. <input type="text" id="wys_pyt[0]">
  10. <input type="text" id="wys_pyt[1]">
  11. <input type="text" id="wys_pyt[2]">
  12. <input type="text" id="wys_pyt[3]">
  13. <input type="button" value="Ile?" onclick="Dodaj()">
  14. </form>
  15. </body>
  16. </html>
MP1
Działa... Zmieniłem NAME na ID, choć nie wiem, czy php będzie to poprawnie interpretował.

ALE...

Kod
ileusr++;
ii=ileusr+1;
document.getElementById("odp"+ii).innerHTML='<input type="text" id="odp'+ileusr+'" name="odp['+ileusr+']" />';
Nie wiem, dlaczego nie działa... Istnieje znacznik SPAN z odpowiednim ID.
To jest wersja lo-fi głównej zawartości. Aby zobaczyć pełną wersję z większą zawartością, obrazkami i formatowaniem proszę kliknij tutaj.
Invision Power Board © 2001-2025 Invision Power Services, Inc.