本文实例讲述了js实现的光标位置工具函数。分享给大家供大家参考,具体如下:
这里介绍的一款textarea中光标位置工具函数的例子。
文本框:
js代码:
textLength){
startPos = textLength;
}
if(endPos > textLength){
endPos = textLength;
}
if(startPos < 0){
startPos = textLength + startPos;
}
if(endPos < 0){
endPos = textLength + endPos;
}
if(textDom.createTextRange){
// IE Support
var range = textDom.createTextRange();
range.moveStart("character",-textLength);
range.moveEnd("character",-textLength);
range.moveStart("character",startPos);
range.moveEnd("character",endPos);
range.select();
}else{
// Firefox support
textDom.setSelectionRange(startPos,endPos);
textDom.focus();
}
}
},/**
* 在光标后插入文本
* 参数:
* value [String] 要插入的文本
*/
insertAfterText: function(value) {
var _this = this,selectRange;
if (document.selection) {
// IE Support
textDom.focus();
selectRange = document.selection.createRange();
selectRange.text = value;
textDom.focus();
}else if (textDom.selectionStart || textDom.selectionStart == '0') {
// Firefox support
var startPos = textDom.selectionStart;
var endPos = textDom.selectionEnd;
var scrollTop = textDom.scrollTop;
textDom.value = textDom.value.substring(0,startPos) + value + textDom.value.substring(endPos,textDom.value.length);
textDom.focus();
textDom.selectionStart = startPos + value.length;
textDom.selectionEnd = startPos + value.length;
textDom.scrollTop = scrollTop;
}
else {
textDom.value += value;
textDom.focus();
}
}
};
// ===============================================
// 实例代码
var textareaDom = document.querySelector("#textarea"),setCurPosInput = document.querySelector("#input"),setCurPosBtn = document.querySelector("#setCurPosBtn"),selectText = document.querySelector("#selectText"),setSelectTextBtn = document.querySelector("#setSelectText"),insertAfterTextBtn = document.querySelector("#insertAfterText");
// 获取当前光标位置
textareaDom.addEventListener("keydown",function() {
console.log("getCurPos: " + selectRange.of(textareaDom).getCurPos());
},false);
// 设置当前光标位置
setCurPosBtn.addEventListener("click",function() {
var curPos = parseInt(setCurPosInput.value);
console.log("curPos: " + curPos);
selectRange.of(textareaDom).setCurPos(curPos);
},false);
// 获取选中文字
selectText.addEventListener("mouseup",function() {
console.log("selectText: " + selectRange.of(this).getSelectText());
});
// 选中特定范围的文本
setSelectTextBtn.addEventListener("click",function() {
selectRange.of(textareaDom).setSelectText(0,21);
},false);
// 在光标后插入文本
insertAfterTextBtn.addEventListener("click",function() {
var insertText = "===hello world,I'm insert content.===";
selectRange.of(textareaDom).insertAfterText(insertText);
},false);
更多关于JavaScript相关内容感兴趣的读者可查看本站专题:《》、《》、《》、《》、《》、《》、《》及《》
希望本文所述对大家JavaScript程序设计有所帮助。
原文链接:https://www.f2er.com/js/45437.html