Skocz do zawartości
Zamknięcie Forum PC LAB

Szanowny Użytkowniku,

Informujemy, że za 30 dni tj. 30 listopada 2024 r. serwis internetowy Forum PC LAB zostanie zamknięty.

Administrator Serwisu Forum PC LAB - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie: wypowiada całość usług Serwisu Forum PC LAB z zachowaniem miesięcznego okresu wypowiedzenia.

Administrator Serwisu Forum PC LAB informuje, że:

  1. Z dniem 29 listopada 2024 r. zakończy się świadczenie wszystkich usług Serwisu Forum PC LAB. Ważną przyczyną uzasadniającą wypowiedzenie jest zamknięcie Serwisu Forum PC LAB
  2. Dotychczas zamowione przez Użytkownika usługi Serwisu Forum PC LAB będą świadczone w okresie wypowiedzenia tj. do dnia 29 listopada 2024 r.
  3. Po ogłoszeniu zamknięcia Serwisu Forum od dnia 30 października 2024 r. zakładanie nowych kont w serwisie Forum PC LAB nie będzie możliwe
  4. Wraz z zamknięciem Serwisu Forum PC LAB, tj. dnia 29 listopada 2024 r. nie będzie już dostępny katalog treści Forum PC LAB. Do tego czasu Użytkownicy Forum PC LAB mają dostęp do swoich treści w zakładce "Profil", gdzie mają możliwość ich skopiowania lub archiwizowania w formie screenshotów.
  5. Administrator danych osobowych Użytkowników - Ringier Axel Springer Polska sp. z o.o. z siedzibą w Warszawie zapewnia realizację praw podmiotów danych osobowych przez cały okres świadczenia usług Serwisu Forum PC LAB. Szczegółowe informacje znajdziesz w Polityce Prywatności

Administrator informuje, iż wraz z zamknięciem Serwisu Forum PC LAB, dane osobowe Użytkowników Serwisu Forum PC LAB zostaną trwale usunięte ze względu na brak podstawy ich dalszego przetwarzania. Proces trwałego usuwania danych z kopii zapasowych może przekroczyć termin zamknięcia Forum PC LAB o kilka miesięcy. Wyjątek może stanowić przetwarzanie danych użytkownika do czasu zakończenia toczących się postepowań.

Temat został przeniesiony do archiwum

Ten temat przebywa obecnie w archiwum. Dodawanie nowych odpowiedzi zostało zablokowane.

Cabalerio

[JS] Porównanie haseł w formularzu

Rekomendowane odpowiedzi

Wczoraj zacząłem się uczyć javascripta i napotkałem na dość dziwny dla mnie problem. Chciałem zrobić skrypt który będzie porównywał 2 hasła i wyświetlał komunikat jeszcze zanim się potwierdzi formularz. Zrobiłem więc proste zdarzenie:

 

function sprawdz_hasla()
{
var div = document.getElementById('poprawnosc'); 
var f = document.forms['formularz'];

haslo = f.haslo.value;
haslo2 = f.haslo2.value;

if((haslo != undefined ) && (haslo2 != undefined))
{
	if(haslo == haslo2)
	{
		div.innerHTML= 'Hasła są poprawne';
		div.style.background='#00ff00';
		blad_hasla = 0;	
	}
	else
	{
		div.innerHTML= 'Hasła nie są identyczne';
		div.style.background='#ff0000';
		blad_hasla = 1;
	}
}
}

 

Przypisane jest ono do pól w ten sposób:

 

<td>
<input onkeyup="sprawdz_hasla()" type="password" name="haslo"/>					
</td>
<td>
<input onkeyup="sprawdz_hasla()" type="password" name="haslo2"/>					
</td>

 

Denerwuje mnie fakt, że skrypt wypisuje mi błąd o niepoprawności haseł jeszcze zanim wpisze drugie hasło. Chciałbym żeby skrypt poczekał, aż oba hasła będą wypełnione. Nie wiem co zmienić, żeby to poprawić.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

daj sprawdz_hasla pod jakiś osobny guzik (np. dalej) a nie onchange z pól edit

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Nie podoba mi się ta myśl, to ma wyglądać tak jak pod tym linkiem: Rejestracja WP

Chciałbym żeby to się sprawdzało automatem. Przy okazji zerżnąłem pomysł z onkeyup="sprawdz_hasla()" teraz działa wiele dynamiczniej, ale wciąż nie tak jak bym chciał.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

to jeszcze dodaj != ''

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Przerobiłem funkcję tak:

 

function sprawdz_hasla()
{
var div = document.getElementById('poprawnosc'); 
var f = document.forms['formularz'];

haslo = f.haslo.value;
haslo2 = f.haslo2.value;

if((haslo != 'undefined' ) && (haslo2 != 'undefined')) // - nie działa
{
	if(haslo.value.length > 4) // - nie działa
	{
		if(haslo == haslo2)
		{
			div.innerHTML= 'Hasła są poprawne';
			div.style.background='#00ff00';
			blad_hasla = 0;	
		}
		else
		{
			div.innerHTML= 'Hasła nie są identyczne';
			div.style.background='#ff0000';
			blad_hasla = 1;
		}
	}
	else
	{
		div.innerHTML= 'Hasła są zbyt krótkie';
		div.style.background='#ff0000';
		blad_hasla = 1;
	}
}
}

 

No i oczywiście teraz nie działa w ogóle. Te części kodu co zaznaczyłem według mnie w ogóle się nie wykonują albo bugują cały skrypt. Czuje się jak jakiś nowicjusz...

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Najpierw musisz podjąć decyzję projektową jak rozpoznasz, że użytkownik już skończył pisać. Możesz np. użyć zdarzenia onblur (walidacja odpali się gdy użytkownik w jakiś sposób "wyjdzie" z pola (np. wciśnie tab, albo kliknie myszka poza polem). Możesz też zrobić warunek w rodzaju braku wciśniętego klawisza, przez x sekund, ale to dużo trudniej obkodować.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

Trudność nie gra roli, ma być zrobione idealnie bez kompromisów. Przyznam szczerze, że nie pomyślałem o tej drugiej możliwości, a zapowiada się dość dobrze. Wieczorem postaram się napisać coś od nowa.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

No to jak się zabierasz za odczekiwanie to poczytaj o funkcjach setTimeout i clearTimeout.

Udostępnij tę odpowiedź


Odnośnik do odpowiedzi
Udostępnij na innych stronach

  • Ostatnio przeglądający   0 użytkowników

    Brak zarejestrowanych użytkowników przeglądających tę stronę.

×
×
  • Dodaj nową pozycję...