js獲取輸入框中當前光標位置並在此位置插入字符串的方法(angularjs+ts)


一半是參照別人代碼,一半是自己代碼,略笨拙,如果有更好的方法希望分享。

  1. 獲取當前光標位置的方法

  2. getCaretPosition (obj:any) {                    //獲取輸入框中當前光標的位置,obj為此輸入框
            let $scope = this.$scope;
            let $log = this.$log;
            $scope.caretPosition = 0;
            if (document.selection) {
                obj.focus();
                var oSel = document.selection.createRange();
                oSel.moveStart('character', -obj.value.length);
                $scope.caretPosition = oSel.text.length;
            }else if (obj.selectionStart || obj.selectionStart == '0'){
                $scope.caretPosition = obj.selectionStart;
            }
            console.log( $scope.caretPosition)
        }

    出處

 

   2.在當前光標位置處插入字符串

  1. insert_flg(oldStr:any,insertStr:any,caretPos:any){
    //oldStr:原字符串,insertStr:要插入的字符串,caretPos:要插入的位置
            var newstr="";
            var tmp1=oldStr.substring(0, caretPos);
            var tmp2=oldStr.substring(caretPos,oldStr.length );
            newstr+=tmp1+insertStr+tmp2;
            return newstr;
    }

    調用時傳入的第三個參數就是第一步中獲取到的當前光標位置。


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM