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;
    }

    调用时传入的第三个参数就是第一步中获取到的当前光标位置。

转载于:https://www.cnblogs.com/li-you/p/6122707.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值