chooseCommonWord(item) {
this.insertMessage(item.content);
},
// 编辑消息(可以从中间选定光标插入消息)
insertMessage(content) {
const input = document.getElementById('message_textarea');
const { start, end } = this.getCursorPosition(input);
if (start !== -1) {
const reverseOrder = this.message.length - end;
this.message =
this.message.slice(0, start) + content + this.message.slice(end);
this.commonPopupShow = false;
this.setCursorPosition(input, this.message.length - reverseOrder);
} else {
// 出现兼容性问题就直接在后面追加
this.message += content;
input.focus();
}
},
// 获取输入框光标位置
getCursorPosition(element) {
let position = {
start: -1,
end: -1,
};
if (element.selectionStart || element.selectionStart === 0) {
position.start = element.selectionStart;
position.end = element.selectionEnd;
}
return position;
},
// 设置输入框光标位置
setCursorPosition(element, start, end) {
if (element.setSelectionRange) {
element.focus();
setImmediate(() => {
element.setSelectionRange(start, end ?? start);
});
}
}
输入框从中间选定光标插入自定义内容
最后编辑于 :
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。