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

简介: 如何获取与设置光标在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>

image.png

设置光标位置



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>

image.png

尾言


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

相关文章
|
缓存 前端开发 JavaScript
flask各种版本的项目,终端命令运行方式的实现
flask各种版本的项目,终端命令运行方式的实现
953 4
|
JavaScript 前端开发 UED
JS实现绑定事件监听的几种方法详解
JS实现绑定事件监听的几种方法详解
517 0
|
存储 JavaScript 前端开发
oss使用SDK上传文件
oss使用SDK上传文件
3536 2
|
2月前
|
缓存 Rust 开发者
UV详解:替代pip、conda的下一代Python包与环境管理工具
UV是Astral团队推出的Rust编写的高性能Python包管理工具,旨在解决pip与conda在速度、功能割裂、环境不一致和资源冗余等方面的痛点。它集包安装、虚拟环境、依赖锁定、Python版本管理、脚本运行及打包发布于一体,兼容现有生态,安装速度快10–100倍,轻量高效,适合纯Python项目开发与团队协作。(239字)
1226 8
|
移动开发 JavaScript 应用服务中间件
Taro——H5项目如何修改静态文件入口
这里我们说两种情况,一种是在静态资源引入的时候加入前缀,另一种是真正的将静态资源输出到指定的目录下。
285 2
|
网络协议 网络安全 PHP
使用天猫精灵实现计算机WOL网络唤醒
解决笔记本连显示器不想掀盖子开机和远程办公时给公司电脑开机不方便的痛点。
15994 8
使用天猫精灵实现计算机WOL网络唤醒
|
移动开发 JavaScript 前端开发
webpack学习四:使用webpack配置plugin,来使用HtmlWebpackPlugin、uglifyjs-webpack-plugin、webpack-dev-server等插件简化开发
这篇文章主要介绍了如何通过配置Webpack的插件,如HtmlWebpackPlugin、uglifyjs-webpack-plugin和webpack-dev-server,来简化前端开发流程。
717 0
webpack学习四:使用webpack配置plugin,来使用HtmlWebpackPlugin、uglifyjs-webpack-plugin、webpack-dev-server等插件简化开发
|
安全 Java 数据安全/隐私保护
【开题报告】基于SpringBoot的高校实验室管理系统的设计与实现
【开题报告】基于SpringBoot的高校实验室管理系统的设计与实现
1215 0
|
JavaScript 前端开发 C++
CommonJS和ES6模块规范有何区别
【8月更文挑战第21天】
538 8

热门文章

最新文章

下一篇
开通oss服务