作家
登录

js操作textarea 常用方法总结

作者: 来源:www.28hudong.com 2013-03-30 00:19:44 阅读 我要评论

在DOM里面操作textarea里面的字符,是比较麻烦的。 于是我有这个封装分享给大家,测试过IE6,8, firefox ,chrome, opera , safari。兼容没问题。 注意:在firefox下 添加字符串的时候有个bug 就是scrollTop 会等于0,当然解决了,但是不够完美。如果有高手也研究过,麻烦指点下。 复制代码 代码如下: var TT = { /* * 获取光标位置 * @Method getCursorPosition * @param t element * @return number */ getCursorPosition: function(t){ if (document.selection) { t.focus(); var ds = document.selection; var range = ds.createRange(); var stored_range = range.duplicate(); stored_range.moveToElementText(t); stored_range.setEndPoint("EndToEnd", range); t.selectionStart = stored_range.text.length - range.text.length; t.selectionEnd = t.selectionStart + range.text.length; return t.selectionStart; } else return t.selectionStart }, /* * 设置光标位置 * @Method setCursorPosition * @param t element * @param p number * @return */ setCursorPosition:function(t, p){ this.sel(t,p,p); }, /* * 插入到光标后面 * @Method add * @param t element * @param txt String * @return */ add:function (t, txt){ var val = t.value; if(document.selection){ t.focus() document.selection.createRange().text = txt; } else { var cp = t.selectionStart; var ubbLength = t.value.length; var s = t.scrollTop; // document.getElementById('aaa').innerHTML += s + '<br/>'; t.value = t.value.slice(0,t.selectionStart) + txt + t.value.slice(t.selectionStart, ubbLength); this.setCursorPosition(t, cp + txt.length); // document.getElementById('aaa').innerHTML += t.scrollTop + '<br/>'; firefox=navigator.userAgent.toLowerCase().match(/firefox/([d.]+)/) && setTimeout(function(){ if(t.scrollTop != s) t.scrollTop=s; },0) }; }, /* * 删除光标 前面或者后面的 n 个字符 * @Method del * @param t element * @param n number n>0 后面 n<0 前面 * @return * 重新设置 value 的时候 scrollTop 的值会被清0 */ del:function(t, n){ var p = this.getCursorPosition(t); var s = t.scrollTop; var val = t.value; t.value = n > 0 ? val.slice(0, p - n) + val.slice(p): val.slice(0, p) + val.slice(p - n); this.setCursorPosition(t ,p - (n < 0 ? 0 : n)); firefox=navigator.userAgent.toLowerCase().match(/firefox/([d.]+)/) && setTimeout(function(){ if(t.scrollTop != s) t.scrollTop=s; },10) }, /* * 选中 s 到 z 位置的文字 * @Method sel * @param t element * @param s number * @param z number * @return */ sel:function(t, s, z){ if(document.selection){ var range = t.createTextRange(); range.moveEnd('character', -t.value.length); range.moveEnd('character', z); range.moveStart('character', s); range.select(); }else{ t.setSelectionRange(s,z); t.focus(); } }, /* * 选中一个字符串 * @Method sel * @param t element * @param s String * @return */ selString:function(t, s){ var index = t.value.indexOf(s); index != -1 ? this.sel(t, index, index + s.length) : false; } }

  推荐阅读

  JSON语法五大要素图文介绍

JSON语法是一种轻量级的数据交换格式。易于人阅读和编写。同时也易于机器解析和生成,下面就进行学习研究,希望本文能教会你更多东西。 JSON语法开发内容包括:更容易的设计集成、扩充的部署选项、更为丰富多彩的登>>>详细阅读


本文标题:js操作textarea 常用方法总结

地址:http://www.17bianji.com/kaifa2/JS/22902.html

关键词: 探索发现

乐购科技部分新闻及文章转载自互联网,供读者交流和学习,若有涉及作者版权等问题请及时与我们联系,以便更正、删除或按规定办理。感谢所有提供资讯的网站,欢迎各类媒体与乐购科技进行文章共享合作。

网友点评
自媒体专栏

评论

热度

精彩导读
栏目ID=71的表不存在(操作类型=0)