• Najnowsze pytania
  • Bez odpowiedzi
  • Zadaj pytanie
  • Kategorie
  • Tagi
  • Zdobyte punkty
  • Ekipa ninja
  • IRC
  • FAQ
  • Regulamin
  • Książki warte uwagi

JQUERY Regex - tylko jeden plus i maksymalnie trzy cyfry

Aruba Cloud VPS - 50% taniej przez 3 miesiące!
+2 głosów
506 wizyt
pytanie zadane 15 grudnia 2021 w JavaScript przez Sebastian Szyja Bywalec (2,950 p.)
edycja 15 grudnia 2021 przez Sebastian Szyja

Hej :))

Mam taki problem, próbuję zrobić walidację prefixu po keyupie:

<input type="text" class="form-control" id="input-prefix" onkeyup="removeFromPrefix(this)" name="prefix" aria-describedby="prefixHelp" value="+48" placeholder="Prefix telefonu kontaktowego" required>

i mam funckję w JS:

function removeFromPrefix(t) {
   var chunked = t.value.split();
 
   for(var i=0; i<chunked.length; i++) {
     if(chunked[i]!='+' && i==0 || i>0 && !Number.isInteger(chunked[i])) {
       chunked[i]='';
       t.value = chunked.join('');
     }
   }
}

ale niestety nie działą mi to :((

 

Problem:

Gdy użytkownik wpisuje + chcaiłbym aby sprawdzić czy jako pierwszy znak może być + jeżeli nie zamienia na pustą wartość "", następnie gdy znak + został wpisany użytkownik wpisuje 4 i skrypt sprawdza czy na drugim miejscu może być cyfra jeżeli nie to znowu pusta wartość "".

Użytkownik musi wpisać: plus na początku oraz maksymalnie trzy cyfry za plusem.

 

Pomoże ktoś to rozwiązać? :)

Pozdrawiam!

komentarz 15 grudnia 2021 przez Sebastian Szyja Bywalec (2,950 p.)

Mam funkcję naprawioną po części:

function removeFromPrefix(t) {
    if(t.value.match(/(\+|00)$/)){
      t.value = t.value.replace(/(\+|00)$/,'');
    }
}

Tylko że plusa nie da się na początku postawić

komentarz 15 grudnia 2021 przez ScriptyChris Mędrzec (190,190 p.)

Nie prościej by było prefix/numer kierunkowy ustawiać w <select> obok <input>? Wtedy mógłbyś łatwiej sprawdzić, czy i jaki prefix jest ustawiony i na tej podstawie sprawdzać zawartość inputa.

komentarz 15 grudnia 2021 przez Sebastian Szyja Bywalec (2,950 p.)
Hmmm... nie głupie rozwiązanie - tylko znowu teraz musze posiadać wszystkie prefixy :(( a chciałbym zrobić to wyrażeniem REGEX
komentarz 16 grudnia 2021 przez Milesq Nałogowiec (32,020 p.)

@Sebastian Szyja, dlaczego w tytule umieściłeś nazwę jquery?

3 odpowiedzi

+1 głos
odpowiedź 15 grudnia 2021 przez Chess Szeryf (76,710 p.)
edycja 15 grudnia 2021 przez Chess
var chunked = t.value.split();

for(var i=0; i<chunked.length; i++) {
  if(chunked[i]!='+' && i==0 || i>0 && !Number.isInteger(chunked[i])) {
    chunked[i]='';
    t.value = chunked.join('');
  }
}

 

komentarz 15 grudnia 2021 przez Sebastian Szyja Bywalec (2,950 p.)
nie działą :(( po wpisaniu cyfry po plusie usuwa wartość z pola :((
komentarz 15 grudnia 2021 przez Chess Szeryf (76,710 p.)
Jeżeli znak drugi lub dalszy nie jest cyfrą, usuń go z pola danych wprowadzonych.

Kod zmieniłem, przepisz od nowa.
komentarz 15 grudnia 2021 przez Sebastian Szyja Bywalec (2,950 p.)
dalej to samo.. przekleiłem Twój skrypt do głównego pytania. mozesz przetestować klikając CodePen u góry badź JSFIDDLE
0 głosów
odpowiedź 15 grudnia 2021 przez Sebastian Szyja Bywalec (2,950 p.)

Poprawne: 

function removeFromPrefix(t) {
   var chunked = t.value.split('');
 
  for(var i=0; i<chunked.length; i++) {
  	console.log(Number(chunked[i]));
    if((chunked[i]!='+' && i==0) || (i>0 && isNaN(Number(chunked[i]))) || i>3 ) {
    	chunked[i]='';
      t.value = chunked.join('');
    }
  

  }

}

 

komentarz 15 grudnia 2021 przez Chess Szeryf (76,710 p.)
Można jeszcze z isString.
0 głosów
odpowiedź 16 grudnia 2021 przez VBService Ekspert (256,320 p.)

Może zamiast onkeyup użyj onkeydown, "plusa" wstaw przed input, np.:

+ <input type="text" class="form-control" id="input-prefix" 
   onkeydown="removeFromPrefix(event)" 
   name="prefix" aria-describedby="prefixHelp" 
   value="" placeholder="Prefix telefonu kontaktowego" required />
function removeFromPrefix(e) {
  const allow = [ 'Backspace', 'Delete', 'ArrowRight', 'ArrowLeft' ];
  
  if (!parseInt(e.key) && e.key != "0" && !allow.includes(e.code)) e.preventDefault();
  if (e.target.value.length >= 3 && !allow.includes(e.code)) e.preventDefault();
}

 

Podobne pytania

0 głosów
2 odpowiedzi 1,611 wizyt
pytanie zadane 17 października 2017 w C i C++ przez Shiro Stary wyjadacz (10,300 p.)
0 głosów
1 odpowiedź 156 wizyt
pytanie zadane 20 kwietnia 2019 w PHP przez hiper007 Stary wyjadacz (11,270 p.)
0 głosów
2 odpowiedzi 189 wizyt
pytanie zadane 21 sierpnia 2018 w Java przez kingkushlee Gaduła (3,960 p.)

93,176 zapytań

142,188 odpowiedzi

321,982 komentarzy

62,508 pasjonatów

Advent of Code 2024

Top 15 użytkowników

  1. 1637p. - dia-Chann
  2. 1614p. - Łukasz Piwowar
  3. 1599p. - CC PL
  4. 1597p. - Łukasz Eckert
  5. 1572p. - Tomasz Bielak
  6. 1545p. - Michal Drewniak
  7. 1537p. - Łukasz Siedlecki
  8. 1531p. - rucin93
  9. 1509p. - rafalszastok
  10. 1506p. - Marcin Putra
  11. 1487p. - Adrian Wieprzkowicz
  12. 1356p. - ssynowiec
  13. 1341p. - Mikbac
  14. 1169p. - Grzegorz Aleksander Klementowski
  15. 1155p. - Piotr Aleksandrowicz
Szczegóły i pełne wyniki

Motyw:

Akcja Pajacyk

Pajacyk od wielu lat dożywia dzieci. Pomóż klikając w zielony brzuszek na stronie. Dziękujemy! ♡

Oto polecana książka warta uwagi.
Pełną listę książek znajdziesz tutaj

Wprowadzenie do ITsec, tom 1 Wprowadzenie do ITsec, tom 2

Można już zamawiać dwa tomy książek o ITsec pt. "Wprowadzenie do bezpieczeństwa IT" - mamy dla Was kod: pasja (użyjcie go w koszyku), dzięki któremu uzyskamy aż 15% zniżki! Dziękujemy ekipie Sekuraka za fajny rabat dla naszej Społeczności!

...