preface
Encounter a scene, need some text labels, click automatically add into the text box, at this time need to master how to obtain and set the cursor position in the input box, make a record, record the use method.
Get cursor position
In the DOM of the input, there is a property called selectionStart to get the starting position of the cursor, and a property called selectionEnd to get the ending position.
When the cursor is only selected at a certain location, the two values are the same. The value is a number, and the cursor is marked 0 starting to the left of the first character in the input, 1 between the first character and the second character, and so on.
When the cursor selects a section of text, these two values get the position before and after the selected text, respectively, and the position number is still obtained in the form of the top.
Two points to note:
-
SelectionStart and selectionEnd default to 0 before input is focused.
-
SelectionStart and selectionEnd are the results of selectionStart and selectionEnd, if the cursor selects a position or text and then loses focus.
<body>
<input id="box" value="111"/>
<button onclick="test()">Get cursor position</button>
<script>
function test() {
const input = document.getElementById('box')
console.log(input.selectionStart,input.selectionEnd)
}
</script>
</body>
Copy the code
Setting cursor Position
The setSelectionRange function on input is used to set the cursor position.
Remember to set the input focus to focus before setting it. If not, the cursor will not matter.
Input parameter Two parameters must be passed, one start position and one end position. If both values are set to the same number, the fixed position can be selected. If both values are set to two numbers, it is equivalent to selecting the text between the two positions with the mouse.
There’s a third parameter can set the direction (” forward “|” backward “|” none “), such as counting backward can start on the backward position.
<body>
<input id="box"/>
<button onclick="test()">Get cursor position</button>
<button onclick="test2()">Sets the cursor position between the first and second characters</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>
Copy the code
Stern said
If you feel that the article is helpful to you, welcome to like collection oh, there are any mistakes or suggestions can also leave a message, thank you ~