在 HTML 中,有两种方式来表现文本框:一种是使用<input>元素的单行文本框,另一种是使用 <textarea>的多行文本框。这两个控件非常相似,而且多数时候的行为也差不多。不过,它们之间仍 然存在一些重要的区别。
相对而言,<textarea>元素则始终会呈现为一个多行文本框。要指定文本框的大小,可以使用 rows 和 cols 特性。其中,rows 特性指定的是文本框的字符行数,而 cols 特性指定的是文本框的字符列数 (类似于 <inpu> 元素的 size 特性)。与 <input> 元素不同, <textarea> 的初始值必须要放在 <textarea>和</textarea>之间。
选择文本
上述两种文本框都支持 select()方法,这个方法用于选择文本框中的所有文本。在调用 select() 方法时,大多数浏览器(Opera 除外)都会将焦点设置到文本框中。这个方法不接受参数,可以在任何 时候被调用。
var textbox = document.forms[0].elements["textbox1"];
textbox.select();
在文本框获得焦点时选择其所有文本,这是一种非常常见的做法,特别是在文本框包含默认值的时 候。因为这样做可以让用户不必一个一个地删除文本。
选择(select)事件
与 select()方法对应的,是一个 select 事件。在选择了文本框中的文本时,就会触发 select 事件。不过,到底什么时候触发 select 事件,还会因浏览器而异。
取得选择的文本
虽然通过 select 事件我们可以知道用户什么时候选择了文本,但仍然不知道用户选择了什么文本。HTML5 通过一些扩展方案解决了这个问题,以便更顺利地取得选择的文本。该规范采取的办法是添加 两个属性:selectionStart 和 selectionEnd。这两个属性中保存的是基于 0 的数值,表示所选择 文本的范围(即文本选区开头和结尾的偏移量)。因此,要取得用户在文本框中选择的文本,可以使用 如下代码。
function getSelectedText(textbox){ return textbox.value.substring(textbox.selectionStart, textbox.selectionEnd); }
IE8 及更早的版本中有一个 document.selection 对象,其中保存着用户在整个文档范围内选择 的文本信息;兼容IE8的写法
function getSelectedText(textbox){ if (typeof textbox.selectionStart == "number"){ return textbox.value.substring(textbox.selectionStart, textbox.selectionEnd); } else if (document.selection){ return document.selection.createRange().text; } }
选择部分文本
现在除 select()方法之外,所有文本框都有一个 setSelectionRange() 方法。这个方法接收两个参数:要选择的第一个字符的索引和要选择的最后一个字符之后的字符的索引 (类似于 substring()方法的两个参数)。
textbox.value = "Hello world!"
//选择所有文本
textbox.setSelectionRange(0, textbox.value.length); //"Hello world!"
//选择前 3 个字符
textbox.setSelectionRange(0, 3); //"Hel"
//选择第 4 到第 6 个字符
textbox.setSelectionRange(4, 7); //"o w"
E8 及更早版本支持使用范围选择部分文本。要选择文本框中的部分文本,必须 首先使用 IE 在所有文本框上提供的 createTextRange()方法创建一个范围,并将其放在恰当的位置 上。然后,再使用 moveStart()和 moveEnd()这两个范围方法将范围移动到位。不过,在调用这两个 方法以前,还必须使用 collapse()将范围折叠到文本框的开始位置。此时,moveStart()将范围的起 点和终点移动到了相同的位置,只要再给 moveEnd()传入要选择的字符总数即可。最后一步,就是使 用范围的 select()方法选择文本,如下面的例子所示。
textbox.value = "Hello world!"; var range = textbox.createTextRange(); //选择所有文本 "Hello world!" range.collapse(true); range.moveStart("character", 0); range.moveEnd("character", textbox.value.length); range.select(); //选择前 3 个字符 "Hel" range.collapse(true); range.moveStart("character", 0); range.moveEnd("character", 3); range.select(); //选择第 4 到第 6 个字符 "o w" range.collapse(true); range.moveStart("character", 4); range.moveEnd("character", 3); range.select();
兼容IE8的写法
function selectText(textbox, startIndex, stopIndex){ if (textbox.setSelectionRange){ textbox.setSelectionRange(startIndex, stopIndex); } else if (textbox.createTextRange){ var range = textbox.createTextRange(); range.collapse(true); range.moveStart("character", startIndex); range.moveEnd("character", stopIndex - startIndex); range.select(); } textbox.focus(); }
操作剪贴板
IE 是第一个支持与剪贴板相关事件,以及通过 JavaScript 访问剪贴板数据的浏览器。HTML 5 后来也把剪贴板事件纳入了规范。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持站长技术。
《结合FSO操作写的一个Class》 尚在完善中,基本功能已具备. 也可作为初学者的教...
大家好我是冰河~~ MySQL作为互联网行业使用最多的关系型数据库之一与其免费、开...
在近日更新的博文中,微软盘点了去年 12 月为 OneDrive 添加的新功能和优化。其...
以前在做项目的时候碰到这样的需求。用户希望能够直接输入城市的名字,就能够得...
相信很多人都在使用Chrome浏览器,它流畅的浏览体验得到了不少用户的偏爱,但流...
http://www.manbu.net/Lib/Class1/Sub11/index.asp 原文链接:https://m.jb51.ne...
2021HW — Chrome 0day漏洞 目录 简述 漏洞环境 过程 修复建议 参考 2021HW — C...
由于平时使用的网页文件基本上都是gb2312编码方式,如果通过xmlhttp控件读取的话...
本文实例讲述了TP3.2框架分页相关实现方法。分享给大家供大家参考,具体如下: ...
目录 符号说明 1 点对点信道 1.1 数据链路和帧 1.1.1 链路 1.1.2 数据链路 1.1.3...