Witaj Gościu! ( Zaloguj | Rejestruj )

Forum PHP.pl

 
Reply to this topicStart new topic
> Oznaczanie błędow przy walidacji.
linx
post
Post #1





Grupa: Zarejestrowani
Postów: 100
Pomógł: 3
Dołączył: 25.06.2007

Ostrzeżenie: (0%)
-----


Witam,
napisałem sobie prosty skrypt do walidacji danych, lecz chciał bym zmienić pewną rzecz.
Mianowicie, wysłanie pustego form powoduje ustawienie komunikatów błędów do każdego pola.
Po zmianie opcji /wypełnieniu pola/ chciał bym, aby dany komunikat wracał automatycznie do poprzedniego stanu a nie dopiero po ponownym wysłaniu formatki.
Na chwilę obecną udało mi się zrobić do dla pola RADIO lecz nie wychodzi mi dla pól SELECT
Dodatkowo nie wiem gdzie mam błąd, ponieważ przy dwóch różnych polach RADIO, komunikat znika tylko z pierwszego z drugiego już nie(dopiero po wysyłce formatki).

Poniżej jest JS dla jednego radio i 2 select, do drugiej formatki mam zrobiony JS z dla dwóch różnych RADIO.

Proszę o pomoc.


  1. $(document).ready(function(){
  2.  
  3. var form = $("#formID");
  4. var radio = $("#sex");
  5. var radioInfo = $(".sex");
  6. var select1 = $("#age");
  7. var select1Info = $(".age");
  8. var select2 = $("#city");
  9. var select2Info = $(".city");
  10.  
  11.  
  12. radio.blur(validateRadio);
  13. select1.blur(validateSelect1);
  14. select2.blur(validateSelect2);
  15.  
  16. radio.keyup(validateRadio);
  17. select1.keyup(validateSelect1);
  18. select2.keyup(validateSelect2);
  19.  
  20. radio.change(validateRadio);
  21. select1.change(validateSelect1);
  22. select2.change(validateSelect2);
  23.  
  24.  
  25. form.submit(function(){
  26. if(validateRadio() & validateSelect1() & validateSelect2())
  27. return true
  28. else
  29. return false;
  30. });
  31.  
  32. function validateRadio(){
  33. if($("input[name='sex']:checked").val() == null){
  34. radioInfo.addClass("error");
  35. return false;
  36. } else {
  37. radioInfo.removeClass("error");
  38. return true;
  39. }
  40. }
  41.  
  42. function validateSelect1(){
  43. if(select1.val().length < 1 ){
  44. select1Info.addClass("error");
  45. return false;
  46. } else {
  47. select1Info.removeClass("error");
  48. return true;
  49. }
  50. }
  51.  
  52. function validateSelect2(){
  53. if(select2.val().length < 1 ){
  54. select2Info.addClass("error");
  55. return false;
  56. } else {
  57. select2Info.removeClass("error");
  58. return true;
  59. }
  60. }
  61. });


Ten post edytował linx 1.04.2013, 20:34:01
Go to the top of the page
+Quote Post

Reply to this topicStart new topic
2 Użytkowników czyta ten temat (2 Gości i 0 Anonimowych użytkowników)
0 Zarejestrowanych:

 



RSS Aktualny czas: 23.08.2025 - 12:50