首页 > 其他分享 >输入框文本选取

输入框文本选取

时间:2022-11-23 10:48:21浏览次数:55  
标签:selection 文本 选取 输入框 选区 选中 txt 光标

一、“选区”和“光标”是什么?

  1. Selection 对象表示用户选择的文本范围或插入符号的当前位置。它代表页面中的文本选区,可能横跨多个元素。通常由用户拖拽鼠标经过文字而产生。

  2. Range对象表示包含节点和部分文本节点的文档片段。通过 selection 对象获得的 range 对象才是我们操作光标的重点。获取 selection ,可以通过全局的 getSelection[3] 方

const selection = window.getSelection();

 

 

 

通常情况下我们不会直接操作 selection 对象,而是需要操作用 seleciton 对象所对应的用户选择的 range 。获取方式如下:

const range = selection.getRangeAt(0)

 

 

 

为什么这里 getRangeAt需要传一个序列呢,难道选区还能有几个吗?还真是,只不过目前只有 Firefox 支持多选区,通过cmd键(windows 上是 ctrl键)可以实现多选区

 

 

可以看到,此时 selection 返回的 rangeCount为 5。不过大部分情况下都不需要考虑多选区的情况。

如果想获取选中的文本内容也非常简单,直接toString 就可以了

window.getSelection().toString()
// 或者
window.getSelection().getRangeAt(0).toString()

 

 

再看一个range返回的一个属性,collapsed,表示选区的起点与终点是否重叠。当collapsedtrue时,

选中区域被压缩成一个点,对于普通的元素,可能什么都看不到,如果是在可编辑元素上,那这个被压缩的点就变成了可以闪烁的光标

 

 所以,光标就是一种起始点相同的选区

1. 主动选中某一区域

表单元素选中区域可以用到 setSelectionRange[4]方法

inputElement.setSelectionRange(selectionStart, selectionEnd [,selectionDirection]);

有 3 个 参数,分别是 selectionStart (起始位置 )、 selectionEnd ( 结束位置)和 selectionDirection(方向)

比如我们想主动选中前两个字 “阅文”,那么可以

btn.onclick = () => {  
    txt.setSelectionRange(0,2);  
    txt.focus();
}

 

如果想全部选中,可以直接用 select 方法

btn.onclick = () => {  
    txt.select();  
    txt.focus();
}

 

2. 聚焦到某一位置

如果我们想把光标移动到“阅文”的后面,根据前面所讲,光标其实是选区起始位置相同的产物,所以可以这样

btn.onclick = () => { 
    txt.setSelectionRange(2,2); // 设置起始点相同   
    txt.focus();
}

 

 

3. 还原之前的选区

有时候,我们需要在点击其他地方后,再重新选中之前的选区。这就需要先记录一下之前选区的起始位置,然后主动设置一下就行了

选区的起始位置,可以用 selectionStartselectionEnd这两个属性来获取,所以

 

const pos = {}
document.onmouseup = (ev) => { 
    pos.start = txt.selectionStart;  
    pos.end = txt.selectionEnd;
}
btn.onclick = () => {  
    txt.setSelectionRange(pos.start,pos.end)  
    txt.focus();
}

 

 

 

 

 

4. 在指定选区插入(替换)内容

表单输入框插入内容需要用到 setRangeText[5] 方法,

inputElement.setRangeText(replacement);

inputElement.setRangeText(replacement,start, end [,selectMode]);

这个方法有两种形式,第2中形式有 4 个参数,第一个参数 replacement ,表示需要替换的文本,然后startend是起始位置,默认是该元素当前选中区域,最后一个参数selectMode,表示替换后选区的状态,有 4 个可选项

select 替换后选中

start 替换后光标位于替换词之前

end 替换后光标位于替换词之后

preserve 默认值,尝试保留选区

比如,我们在选区插入或替换成一段文本“❤️❤️❤️”,可以这样:

 

btn.onclick = () => {  
    txt.setRangeText('❤️❤️❤️')   
    txt.focus();
}

 

 

 

 

标签:selection,文本,选取,输入框,选区,选中,txt,光标
From: https://www.cnblogs.com/wxyblog/p/16915700.html

相关文章

  • 富文本中提取文本的方法分享
    转自:http://www.java265.com/JavaJingYan/202205/16534860003509.html  下文笔者讲述从java代码从富文本html中提取文本内容的方法分享,如下所示今天接到一个需求,将富......
  • linux文本工具
    目录一、文本工具 1一、文本编辑工具Vim 1二、文本文件查看命令cat 3三、more命令描述:more命令从前向后分页显示文件内容。 4四、Less命令描述 4五、head命令描述 5六、s......
  • H5 富文本快捷输入
    ✍记录一下功能富文本功能快捷键关键词效果......
  • 15:文本文件的读取
    ###文本文件的读取 文件的读取一般使用如下三个方法:1.read([size])从文件中读取size个字符,并作为结果返回。如果没有size参数,则读取整个文件。读取到文件末尾,会......
  • FileReader之获取文本文件内容为字符串
    FileReader之获取文本文件内容为字符串FileReader官网描述:FileReader对象允许Web应用程序异步读取存储在用户计算机上的文件(或原始数据缓冲区)的内容,使用File或Blob......
  • vusui-editor富文本编辑器
    Vusui-editor基于Vue3+Quill封装的富文本编辑器组件【使用文档】|【在线演示】......
  • 文本转语音
    WebSpeechAPI有两个部分:SpeechSynthesis语音合成(文本到语音TTS)和SpeechRecognition 语音识别(异步语音识别)SpeechSynthesis.cancel():移除所有语音队列中的谈话。......
  • flex布局处理文本溢出
    <!DOCTYPEhtml><htmllang="en"><head><metacharset="UTF-8"><title>flex布局处理文本溢出</title><style>.container{display:flex;}.left......
  • 删除按钮:先删除为空的输入框,再从下往上删除输入框
    在点击删除按钮是他总是将第一个输入框/输入框内有数据的给删除掉;所以将代码改写为‘先删除为空的输入框,再从下往上删除输入框’<el-col:span="12"><el-form-......
  • 对‘将输入框内的值传输给后台’的代码优化/简化
    原代码是将输入框的值在点击确认或者下一步的按钮事件中添加以下代码:来确保将绑定输入框的数组转化成字符串传给后台this.base.Number="";for(leti=0;i......