Curs Javascript

In acest tutorial e prezentat modul prin care se pot verifica /valida pe partea de client (cu JavaScript) valorile adaugate in campuri text in formular, caracterele permise (specificate cu un cod RegExp) si numarul lor.
Aici e un exemplu simplu, cu 3 casute de text. Se preia datele din fiecare camp din formular si se verifica pe rand fiecare.
Similar se apica si la formulare cu mai multe casute de tip text si textarea. Vedeti explicatiile de mai jos si cele din cod.

<i>- Numele si Parola trebuie sa contina doar numere, litere si liniute "-", "_".<br/>
- Numele intre 3 si 18 caractere, Parola intre 7 si 18 caractere.</i>
<form action="" method="post" onsubmit="return checkForm(this);">
 <label for="nume1">Nume:</label> <input type="text" name="nume1" id="nume1" /><br/>
 <label for="pass1">Parola:</label> <input type="password" name="pass1" id="pass1" /><br/>
 <label for="email1">E-mail:</label> <input type="text" name="email1" id="email1" /><br/>
 <input type="submit" name="fsubmit" id="fsubmit" value="Submit" />
</form>
<script type="text/javascript"><!--
// RegExp care sa permite doar litere, numere si liniute "-", "_"
var regx_chr = /^([a-zA-Z0-9_-]+)$/;
var regx_mail = /^([a-zA-Z0-9]+[a-zA-Z0-9._%-]*@([a-zA-Z0-9-]+\.)+[a-zA-Z]{2,4})$/;    // RegExp pt. adresa e-mail

// Functia care e apelata la "onsubmit"
// preia campurile din formular, verifica /valideaza datele adaugate
function checkForm(frm1) {
  var fre = false;             // variabila ce va fi returnata de functie

  // preluare casete formular
  var nume1 = frm1.nume1;
  var pass1 = frm1.pass1;
  var email1 = frm1.email1;

  // verificare valori (Nume, Parola, E-mail), daca sunt incorecte, returneaza alert si selecteaza casuta
  if(nume1.value.length<3 || nume1.value.length>18 || nume1.value.search(regx_chr)==-1) {
    alert('Numele trebuie sa contina intre 3 si 18 caractere \nNumere, Litere, "-" si "_"');
    nume1.select();    // selecteaza casuta pt. Nume
  }
  else if(pass1.value.length<7 || pass1.value.length>18 || pass1.value.search(regx_chr)==-1) {
    alert('Parola trebuie sa contina intre 7 si 18 caractere \nNumere, Litere, "-" si "_"');
    pass1.select();    // selecteaza casuta pt. Parola
  }
  else if(email1.value.search(regx_mail)==-1) {
    alert('Adaugati o adresa de e-mail corecta');
    email1.select();    // selecteaza casuta pt. E-mail
  }
  else fre = true;

  return fre;
}
--></script>
Cand se apasa butonul Submit (sau Enter in casuta) pentru trimitere formular, e activat evenimentul "onsubmit" care prin "return checkForm(this);" apeleaza si returneaza rezultatul functiei "checkForm()".
- "this" reprezinta "acesta", adica formularul.
Functia returneaza valoarea unei variabile (fre) setata initial false.
Parametrul "frm1" retine formularul, transferat cu "this".
Formula "frm1.nume_casuta" preia acea casuta din formular ("nume_casuta" e numele casutei adagata la atributul "name").
Prin adaugarea lui "value" se preia valoarea /datele din ea, iar cu "length" se obtine numarul de caractere.
Daca la verificarea datelor valorile nu corespund cu cele ce trebuie adaugate, afiseaza un mesaj in fereastra alert, iar variabila "fre" returnata ramane false, ceea ce determina netrimiterea formularului.
Daca valorile sunt corecte, ultima instructiune: "else fre = true;" , seteaza variabila true, ceea ce determina trimiterea formularului.

- Codul de mai sus va afisa urmatorul formular:
- Numele si Parola trebuie sa contina doar numere, litere si liniute "-", "_".
- Numele intre 3 si 18 caractere, Parola intre 7 si 18 caractere.



Un Test simplu in fiecare zi

HTML
CSS
JavaScript
PHP-MySQL
Engleza
Spaniola
Ce tag se foloseste pentru a adauga liste in elemente <ul> si <ol>?
<dt> <dd> <li>
<ul>
 <li>http://coursesweb.net/html/</li>
 <li>http://www.marplo.net/html/</li>
</ul>
Care valoare a proprietatii "display" seteaza elementul ca tip bloc si afiseaza un punct in fata?
block list-item inline-block
.some_class {
  display: list-item;
}
Care instructiune JavaScript transforma un obiect in sir JSON.
JSON.parse() JSON.stringify eval()
var obj = {
 "courses": ["php", "javascript", "ajax"]
};
var jsonstr = JSON.stringify(obj);
alert(jsonstr);    // {"courses":["php","javascript","ajax"]}
Indicati clasa PHP folosita pentru a lucra cu elemente HTML si XML in PHP.
stdClass PDO DOMDocument
$strhtml = '<body><div id="dv1">CoursesWeb.net</div></body>';
$dochtml = new DOMDocument();
$dochtml->loadHTML($strhtml);
$elm = $dochtml->getElementById("dv1");
echo $elm->nodeValue;    // CoursesWeb.net
Indicati forma de Prezent Continuu a verbului "to live" (a trai /a locui)
lived living liveing
I`m living here.
- Traiesc /Locuiesc aici.
Care este forma de Gerunziu (sau Participiu Prezent) a verbului "vivir" (a trai /a locui)?
viviĆ³ vivido viviendo
Estoy viviendo aquĆ­.
- Traiesc /Locuiesc aici.
Verificare si Validare caractere din formular

Last accessed pages

  1. Trecutul simplu si continuu - Past Tense Simple and Continuous (81333)
  2. Adjective - Exercitii si teste engleza incepatori (16878)
  3. Titluri, Paragrafe, Un nou rand, Linie orizontala (32538)
  4. Curs HTML gratuit Tutoriale HTML5 (193935)
  5. Teste Programare Web (3372)

Popular pages this month

  1. Cursuri si Tutoriale: Engleza, Spaniola, HTML, CSS, Php-Mysql, JavaScript, Ajax (972)
  2. Gramatica limbii engleze - Prezentare Generala (631)
  3. Exercitii engleza - English Tests and exercises - Grammar (561)
  4. Prezentul simplu si continuu - Present Tense Simple and Continuous (459)
  5. Coduri pt culori (367)