Javascript не работает на мобильном телефоне, но работает на рабочем столе для вкладки к следующему полю для четырех ОТП - PullRequest
2 голосов
/ 24 сентября 2019
let element = $event.srcElement.nextElementSibling;
element.focus()

Здесь родной элемент следующего элемента не работает.

если ввести 1-е число в поле 1, то оно автоматически перейдет к следующему полю, оно нормально работает в настольном браузере, но не в мобильном браузере?

<input type="text" #otpvalue1 maxlength="1" [value]="otpValue1" (paste)="pasteEvent($event)" (keypress)="otpBox1($event)" (keydown)="handleBackSpaceBox1($event)"/>
                        <input type="text" #otpvalue2 maxlength="1" [value]="otpValue2" (paste)="pasteEvent($event)"  (keypress)="otpBox2($event)" (keydown)="handleBackSpaceBox2($event)">
                        <input type="text" #otpvalue3 maxlength="1" [value]="otpValue3" (paste)="pasteEvent($event)"  (keypress)="otpBox3($event)" (keydown)="handleBackSpaceBox3($event)">
                        <input type="text" #otpvalue4 maxlength="1" [value]="otpValue4" (paste)="pasteEvent($event)"  (keypress)="otpBox4($event)" (keydown)="handleBackSpaceBox4($event)" />

otpBox1(obj) {
    obj = (obj) ? obj : window.event;
    let charCode = (obj.which) ? obj.which : obj.keyCode;
    if ((charCode > 31 || charCode == 13) && (charCode < 48 || charCode > 57)) {
      return false;
    }
    else {
      this.otpValue1 = obj.key;
      let otplength = this.otpValue1 + this.otpValue2 + this.otpValue3 + this.otpValue4;
      this.otplength = otplength.length;
      let element = obj.srcElement.nextElementSibling;
      if (element != null) {
        element.focus();
        obj.preventDefault();
      }
      return true;
    }
  }


1 Ответ

0 голосов
/ 24 сентября 2019

требуется больше кода .. как вы решаете, стоит ли прыгать вперед?многие события сильно различаются между сенсорными устройствами и теми, которые управляются подключенной клавиатурой и мышью!

...