如何获取与设置光标在input框的位置

前言

遇到一个场景,需要一些文本标签,点击自动添加进文本框,这时候就需要掌握如何获取与设置光标在input框的位置,做一个记录,记录使用方法。

获取光标位置

input的dom上存在一个属性selectionStart可以获取光标起始位置,一个属性selectionEnd为结束位置。

当光标只是选中在某个位置时,这两个值相同,值为数字,光标在input中第一个字符的左边开始记作0,第一个字符和第二个字符之间为1,依次类推。

当光标选种文本的某一段内容时,这两个值分别得到选中文本的前面与后面的位置,位置数字仍然是以上方的形式得到。

需要注意两点:

  1. 一开始input未聚焦前,selectionStart和selectionEnd默认为0。

  2. 如果光标选中了一个位置或者一段文本,再失去焦点,selectionStart与selectionEnd仍然是失去焦点前选中的结果

<body>
<input id="box" value="111"/>
<button onclick="test()">
    获取光标位置
</button>
<script>
    function test() {
        const input = document.getElementById('box')
        console.log(input.selectionStart,input.selectionEnd)
    }
</script>
</body>

在这里插入图片描述

设置光标位置

input上的setSelectionRange函数用于设置光标位置。

记得设置之前先让input聚焦focus,如果没聚焦也就没光标什么事了。

入参两个参数必传,一个开始位置一个结束位置,都设置成同一个数字就可以选中固定位置,如果设置为两个数字,等于用鼠标选中两个位置之间的文本

还有第三个入参可以设置方向(“forward” | “backward” | “none”),比如backward可以从后往前开始计数位置。

<body>
<input id="box"/>
<button onclick="test()">
    获取光标位置
</button>
<button onclick="test2()">
    设置光标位置为第一个字符与第二个字符之间
</button>
<script>
    function test() {
        const input = document.getElementById('box')
        console.log(input.selectionStart)
    }

    function test2(index) {
        const input = document.getElementById('box')
        input.focus()
        input.setSelectionRange(1, 2)
    }
</script>
</body>

在这里插入图片描述

尾言

如果觉得文章对你有帮助的话,欢迎点赞收藏哦,有什么错误或者意见建议也可以留言,感谢~

  • 5
    点赞
  • 33
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

在下月亮有何贵干

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值