Javascript文本框脚本实现方法解析

作者:Terre 时间:2024-04-25 10:36:22 

在 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 后来也把剪贴板事件纳入了规范。

  • beforecopy:在发生复制操作前触发 。

  • copy:在发生复制操作时触发。

  • beforecut:在发生剪切操作前触发。

  • cut:在发生剪切操作时触发。

  • beforepaste:在发生粘贴操作前触发。

  • paste:在发生粘贴操作时触发。

来源:https://www.cnblogs.com/vali/p/13833126.html

标签:Javascript,文本框,脚本
0
投稿

猜你喜欢

  • Python 实现图片转字符画的示例(静态图片,gif皆可)

    2023-04-11 13:42:38
  • Vue使用vux-ui自定义表单验证遇到的问题及解决方法

    2024-05-10 14:18:07
  • IE7新支持的CSS属性和属性选择符

    2008-03-16 14:26:00
  • Python模拟FTP文件服务器的操作方法

    2022-11-11 19:53:04
  • 解决Tensorflow使用pip安装后没有model目录的问题

    2023-08-09 22:58:05
  • pandas 对日期类型数据的处理方法详解

    2021-12-02 04:43:56
  • Python GUI自动化实现绕过验证码登录

    2023-06-25 05:18:25
  • 新建文件时Pycharm中自动设置头部模板信息的方法

    2021-08-18 11:56:46
  • vuex管理状态仓库使用详解

    2024-04-30 10:38:33
  • sql server关键字详解大全(图文)

    2024-01-14 09:43:13
  • Python实现鸡群算法的示例代码

    2022-03-23 19:02:54
  • Python查找算法之分块查找算法的实现

    2023-06-26 20:25:34
  • Python 切片为什么不会索引越界?

    2022-02-22 19:39:47
  • VUE前端cookie简单操作

    2024-04-30 08:44:57
  • Python异常原理及异常捕捉实现过程解析

    2021-04-14 23:05:40
  • bootstrap-table后端分页功能完整实例

    2024-04-29 13:11:44
  • SQL Server储过程加密和解密原理深入分析

    2024-01-20 01:27:12
  • Keras中的多分类损失函数用法categorical_crossentropy

    2023-06-23 12:25:37
  • Python translator使用实例

    2021-02-09 22:40:24
  • 关注oblog 关注xml-rpc 自己开发客户端小记

    2009-10-04 20:27:00
  • asp之家 网络编程 m.aspxhome.com