文字选中的js实现
2013-10-21 21:48
169 查看
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"> <html xmlns="http://www.w3.org/1999/xhtml"> <head> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /> <title>选中文本</title> <style type="text/css"> body{ font-size:12px;} </style> </head> <body> <input type="text" id="song" value="在解放路松岛枫424" /> </body> </html> <script> /* 1. 只受用于一些含有value属性的HTML控件,例如单行文本框、多行文本域; 2. 后面两个参数表示起始字符位置与结束的字符位置,如果位置值为空,或是非数值,则会(从头或至尾或全部)选择字符; 3. 支持负值,负值表意与js中的slice属性一致,负值表示的含义就是负值与字符总长度的和,也可以理解为从末尾开始选择; 4. 如果数值范围超过字符总长,则无内容选择; 5. 支持单参数,省略第三个参数表示一致到字符结束都要选中。 */ var textSelect = function(o, a, b){ //o是当前对象,例如文本域对象 //a是起始位置,b是终点位置 var a = parseInt(a, 10), b = parseInt(b, 10); var l = o.value.length; if(l){ //如果非数值,则表示从起始位置选择到结束位置 if(!a){ a = 0; } if(!b){ b = l; } //如果值超过长度,则就是当前对象值的长度 if(a > l){ a = l; } if(b > l){ b = l; } //如果为负值,则与长度值相加 if(a < 0){ a = l + a; } if(b < 0){ b = l + b; } if(o.createTextRange){//IE浏览器 var range = o.createTextRange(); range.moveStart("character",-l); range.moveEnd("character",-l); range.moveStart("character", a); range.moveEnd("character",b); range.select(); }else{ o.setSelectionRange(a, b); o.focus(); } } }; document.onclick = function(){ var textElem = document.getElementById("song"); textSelect(textElem, 0, 5); } </script>
原文地址:http://www.zhangxinxu.com/wordpress/?p=755
相关文章推荐
- Js 载入时选中文字的实现代码
- 【web前端】js页面文字选中后分享到新浪微博实现
- js实现清除筛选条件功能. js 中jquery.sumoselect 多选控件,去掉多选中多个选中的样式和文字,改成未选中
- 超简单JS实现把鼠标选中文字发送到新浪微博
- js页面文字选中后分享到新浪微博实现
- js实现文字选中分享功能
- 新浪微博插入话题后部分文字选中的js实现
- 【js】点击radio后的文字实现选中效果
- 新浪微博插入话题后部分文字选中的js实现
- js页面文字选中后分享到新浪微博实现
- js实现选中文字 分享功能
- js实现textarea选中文字并加粗
- 转载:js页面文字选中后分享到新浪微博实现
- js实现选中页面文字将其分享到新浪微博
- js+css实现禁止鼠标右键与选中网页文字
- js页面文字选中后分享到新浪微博实现
- js页面文字选中后分享到新浪微博实现
- 转载:js页面文字选中后分享到新浪微博实现
- 不使用js实现点击文字选中radio
- 点击文字实现radio 选中(不使用js)