在前端研发中我们经常需要使用脚本在文本框中插入内容。如果产品要求不能直接插入开始或者尾部,而是要插入到光标位置,此时我们就需要获取光标/光标选中的位置。
很多时候,我在格式化文本处需要选择选项,将选择的信息输入到光标位置
selectionStart & selectionEnd
这两个属性分别对应选中区域的开始位置和结束位置,当没有选中任何内容的时候,两个值相等并且值为光标位置。
const 未来之窗_光标技术_insert = (文本框元素, content) => {
const 当前文本内容 = 文本框元素.value
const 光标开始位置 = 文本框元素.selectionStart
const 光标结束位置 = 文本框元素.selectionEnd
文本框元素.value = 当前文本内容.substring(0, 光标开始位置) + content + 当前文本内容.substring(光标结束位置);
}
function 未来之窗_前端技术_插入当前(eleid,value){
var textAreaElement=document.getElementById(eleid);
未来之窗_光标技术_insert(textAreaElement,value);
}
html
<button id="" type="" onclick="未来之窗_前端技术_插入当前('wlzc_content','0000000000');">插入</button>