首页 > 其他分享 >如何获取与设置光标在input框的位置

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

时间:2022-12-19 22:12:25浏览次数:41  
标签:位置 获取 selectionStart 选中 设置 input 光标

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

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

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

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

需要注意两点:

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

如果光标选中了一个位置或者一段文本,再失去焦点,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>
1
2
3
4
5
6
7
8
9
10
11
12


设置光标位置
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>
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21


尾言
如果觉得文章对你有帮助的话,欢迎点赞收藏哦,有什么错误或者意见建议也可以留言,感谢~
————————————————
版权声明:本文为CSDN博主「在下月亮有何贵干」的原创文章,遵循CC 4.0 BY-SA版权协议,转载请附上原文出处链接及本声明。
原文链接:https://blog.csdn.net/weixin_43877799/article/details/121291979

标签:位置,获取,selectionStart,选中,设置,input,光标
From: https://www.cnblogs.com/mmzuo-798/p/16993215.html

相关文章

  • C#获取文件MD5
    C#获取文件MD5码:<spanstyle="font-size:18px;">staticvoidMain(string[]args){stringcode=GetMD5HashFromFile("123.pdf");}pr......
  • SpringBoot中通过ApplicationContext获取bean对象
    1.定义一个工具类packagecom.example.redis.utils;importcom.example.redis.DemoApplication;importorg.springframework.beans.BeansException;importorg.sprin......
  • Python__07--input
    1input()描述:input()函数是输入性函数,与print()函数类似,input()函数括号里的内容是会显示出来的,但不同在于,我们需要输入对应的内容,回车后才能继续运行。1.1测试代码......
  • Python__07--input
    1input()描述:input()函数是输入性函数,与print()函数类似,input()函数括号里的内容是会显示出来的,但不同在于,我们需要输入对应的内容,回车后才能继续运行。1.1测试代码......
  • Python__07--input
    1input()描述:input()函数是输入性函数,与print()函数类似,input()函数括号里的内容是会显示出来的,但不同在于,我们需要输入对应的内容,回车后才能继续运行。1.1测试代码......
  • Python__07--input
    1input()描述:input()函数是输入性函数,与print()函数类似,input()函数括号里的内容是会显示出来的,但不同在于,我们需要输入对应的内容,回车后才能继续运行。1.1测试代码......
  • 基恩士SR710测试笔记 (同时获取两个条码)
    1,条码1配置入库  2,条码2配置入库  3,设置读取数量  4,分隔符设置  5,设置传送:下载至控制器  6,终端测试 ......
  • ffmpeg使用avformat_close_input()函数释放结构体时崩溃的问题
    先看一下我调试时,发现程序崩溃的代码位置//这是我的程序释放流上下文时的操作if(m_pAvFormatContext){if(m_iVideoStreamIndex>=0)avcodec_free_context(&m......
  • 几种数据库jar包获取方式
    摘要:以下提供的都是各个数据库较为官方的jar包获取方式。本文分享自华为云社区《JDBC连接相关jar包获取及上传管理中心白名单处理》,作者:HuaWeiXYe。jar包获取以下提供......
  • 【Pytest--html报告优化+增加错误截图,获取统计数据】
    一、pytest生成的原始html报告1、在我们实际工作中,环境信息不一定要在报告中详细提现,可以增减2、用例信息,默认展示的是用例的model名::用例名称,并不直观,所以我们可以增加一......