js TextArea的选中区域处理
更新时间:2010年12月28日 23:30:40 作者:
js中对于TextArea的选中区域后进行处理的代码,需要的朋友可以参考下。
(一)获取Textarea的选中区域起点或无选中时的输入光标位置
非IE浏览器,如,firefox,chrome,支持 selectionStart 获取选中区域的起点,而IE浏览器不支持该属性,需要间接通过TextRange来获得,利用TextRange对象的compareEndPoints方法来进行起点的比较可以实现。
getStartPos : function( textarea )
{
if ( typeof textarea.selectionStart != 'undefined' )
{ // 非IE
start = textarea.selectionStart;
}
else
{ // IE
var range = document.selection.createRange();
var range_textarea = document.body.createTextRange();
range_textarea .moveToElementText(textarea);
//比较start point
for ( var sel_start = 0; range_textarea .compareEndPoints('StartToStart' , range) < 0; sel_start++)
range_textarea .moveStart( 'character', 1);
start = sel_start;
} // else
return start;
}
但有点需要注意的是,在chrome下,如果textarea设为readonley,那textarea不会出现输入光标,返回的selectionStart与selectionEnd都为0.firefox下则正常。
(二)设置Textarea中选中的区域
类似的,非IE的浏览器支持setSelectionRange方法指定选中的字符范围,而IE不支持,也是通过TextRange来操作,这里需要注意的是IE下Textarea的选中区间的相对位置问题。如下面的代码是先moveStart,moveEnd把起点与终点都设为0,collapse移动生效后,起点不变,先moveEnd移动区间的终点,再moveStart移动区间的起点,在没有改变起点point之前,可以保证相对位置不变,更容易理解些。
/**
* 设置textarea的选中区域
*/
setSelectRange : function( textarea, start, end )
{
if ( typeof textarea.createTextRange != 'undefined' )// IE
{
var range = textarea.createTextRange();
// 先把相对起点移动到0处
range.moveStart( "character", 0)
range.moveEnd( "character", 0);
range.collapse( true); // 移动插入光标到start处
range.moveEnd( "character", end);
range.moveStart( "character", start);
range.select();
} // if
else if ( typeof textarea.setSelectionRange != 'undefined' )
{
textarea.setSelectionRange(start, end);
textarea.focus();
} // else
}
实现了选中区域获取及设置方法后,其他如文字插入,替换的实现就比较简单了。
非IE浏览器,如,firefox,chrome,支持 selectionStart 获取选中区域的起点,而IE浏览器不支持该属性,需要间接通过TextRange来获得,利用TextRange对象的compareEndPoints方法来进行起点的比较可以实现。
复制代码 代码如下:
getStartPos : function( textarea )
{
if ( typeof textarea.selectionStart != 'undefined' )
{ // 非IE
start = textarea.selectionStart;
}
else
{ // IE
var range = document.selection.createRange();
var range_textarea = document.body.createTextRange();
range_textarea .moveToElementText(textarea);
//比较start point
for ( var sel_start = 0; range_textarea .compareEndPoints('StartToStart' , range) < 0; sel_start++)
range_textarea .moveStart( 'character', 1);
start = sel_start;
} // else
return start;
}
但有点需要注意的是,在chrome下,如果textarea设为readonley,那textarea不会出现输入光标,返回的selectionStart与selectionEnd都为0.firefox下则正常。
(二)设置Textarea中选中的区域
类似的,非IE的浏览器支持setSelectionRange方法指定选中的字符范围,而IE不支持,也是通过TextRange来操作,这里需要注意的是IE下Textarea的选中区间的相对位置问题。如下面的代码是先moveStart,moveEnd把起点与终点都设为0,collapse移动生效后,起点不变,先moveEnd移动区间的终点,再moveStart移动区间的起点,在没有改变起点point之前,可以保证相对位置不变,更容易理解些。
复制代码 代码如下:
/**
* 设置textarea的选中区域
*/
setSelectRange : function( textarea, start, end )
{
if ( typeof textarea.createTextRange != 'undefined' )// IE
{
var range = textarea.createTextRange();
// 先把相对起点移动到0处
range.moveStart( "character", 0)
range.moveEnd( "character", 0);
range.collapse( true); // 移动插入光标到start处
range.moveEnd( "character", end);
range.moveStart( "character", start);
range.select();
} // if
else if ( typeof textarea.setSelectionRange != 'undefined' )
{
textarea.setSelectionRange(start, end);
textarea.focus();
} // else
}
实现了选中区域获取及设置方法后,其他如文字插入,替换的实现就比较简单了。
您可能感兴趣的文章:
- 让textarea自动调整大小的js代码
- javascript textarea光标定位方法(兼容IE和FF)
- 动态调整textarea中字体的大小代码
- 新浪微博字数统计 textarea字数统计实现代码
- Textarea与懒惰渲染实现代码
- 非主流的textarea自增长实现js代码
- 在chrome浏览器中,防止input[text]和textarea在聚焦时出现黄色边框的解决方法
- js操作textarea方法集合封装(兼容IE,firefox)
- JavaScript 获取/设置光标位置,兼容Input&&TextArea
- js封装的textarea操作方法集合(兼容很好)
- javascript实现的textarea运行框效果代码 不用指定id批量指定
- JavaScript 监听textarea中按键事件
- javascript之textarea打字机效果提示代码推荐
- 用javascript获取textarea中的光标位置
- textarea支持图形编辑的实现方法
- 在textarea文本域中显示HTML代码的方法
- 关于textarea的直观换行的一些研究材料
- JS TextArea字符串长度限制代码集合
相关文章
js获取TreeView控件选中节点的Text和Value值的方法
在实际项目中,遇到一个问题,首先弹出一个新窗口,新窗口中放了一个TreeView控件,现在要解决的是,如何单击TreeView中一个节点,返回Text和Value到父页面并关闭该新窗口,本文将详细介绍此方法的实现2012-11-11
最新评论