• 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 - Virtual Private Server VPS
+2 głosów
539 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,730 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,730 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,730 p.)
Można jeszcze z isString.
0 głosów
odpowiedź 16 grudnia 2021 przez VBService Ekspert (256,500 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,631 wizyt
pytanie zadane 17 października 2017 w C i C++ przez Shiro Stary wyjadacz (10,300 p.)
0 głosów
1 odpowiedź 159 wizyt
pytanie zadane 20 kwietnia 2019 w PHP przez hiper007 Stary wyjadacz (11,270 p.)
0 głosów
2 odpowiedzi 194 wizyt
pytanie zadane 21 sierpnia 2018 w Java przez kingkushlee Gaduła (3,960 p.)

93,264 zapytań

142,260 odpowiedzi

322,234 komentarzy

62,582 pasjonatów

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!

...