Angular 5 + Как переместить курсор за символом, используя опции клавиатуры влево / вправо в IE 11 - PullRequest
0 голосов
/ 08 мая 2019

Я использую Angular 5 с Ag-Grid Enterprise Addition. Я использую браузер IE11. К сожалению, в сетке курсор застревает и не перемещается к следующим символам в поле ввода с помощью клавиатуры влево / вправо. Итак, я подумал о явном перемещении курсора к следующим символам. Я использую диапазон Javascript для этого. Я получаю сообщение об ошибке в этой строке document.getSelection (). AddRange (range). Ниже приведен код пользовательского NumericComponent, снимок экрана поля ввода и ошибка. Я не уверен, что это правильный подход. Кто-нибудь может подсказать мне, как решить эту проблему?

<input #input  id="numericinput" style="width: 100%; height: 100%;" (keydown)="onKeyDown($event)" [(ngModel)]="value" (dblclick) = "$event.target.select()">
              <button (click)="clear()" style="position:absolute;top:5px;right:2px;cursor:pointer;color:grey;background-color:white;border:none;">
                <span>&#10060;</span>
              </button>

onKeyDown(event): void {
        var key = event.which || event.keyCode;
        if(key === 37 || key === 39){
          let error ;
          event.stopPropagation();                      
          let inputDocument = document.getElementById('numericinput');    
          let range = document.createRange();
          range.collapse(true);        
          range.setEnd(inputDocument.firstChild, 0);          
          range.setStart(inputDocument.firstChild, this.input.element.nativeElement.value.length);          
          document.getSelection().removeAllRanges;          
          document.getSelection().addRange(range);                          
        }
        if (!this.isKeyPressedNumeric(event)) {
            if (event.preventDefault) event.preventDefault();
        }

    }

enter image description here

1 Ответ

0 голосов
/ 13 мая 2019

Ниже приведено решение, из которого я выполнил задачу

var key = event.which || event.keyCode;
        var iCaretPos = 0;
        if(key === 37 || key === 39){   
            //Left or right       
          let inputDocument = document.getElementById('numericinput');
          const element : HTMLInputElement = <HTMLInputElement>inputDocument;
          event.stopPropagation();                                                  
          let selectionStart = 0;          
          if(key === 39 && this.iCaretPos < element.innerHTML.length+1){               
                selectionStart = this.iCaretPos;
                this.iCaretPos = this.iCaretPos +1;
          }else if(key === 37 && this.iCaretPos !== 0){               
                selectionStart = this.iCaretPos;
                this.iCaretPos = this.iCaretPos -1;
          }  
          let selectionEnd = this.iCaretPos;          
            if (element.setSelectionRange) {                                          
                element.focus();
                element.setSelectionRange(selectionStart, selectionEnd);
            }        
        }
...