欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

js操作textarea方法集合封裝(兼容IE,firefox)

 更新時間:2011年02月22日 23:51:04   作者:  
在DOM里面操作textarea里面的字符,是比較麻煩的。于是我有這個封裝分享給大家,測試過IE6,8, firefox ,chrome, opera , safari。兼容沒問題。
注意:在firefox下 添加字符串的時候有個bug 就是scrollTop 會等于0,當(dāng)然解決了,但是不夠完美。如果有高手也研究過,麻煩指點下。

完整測試代碼:

復(fù)制代碼 代碼如下:

<textarea id="testlujun" style="width: 300px; height: 50px;">abcdefghijklmnopqrstuvwxyz</textarea>
<br />
<input onclick="alert(TT.getCursorPosition(test))" type="button" value="光標位置" />
<input onclick="TT.setCursorPosition(test,3)" type="button" value="設(shè)置光標到3第位置" />
<input onclick="TT.add(test,'你好')" type="button" value="添加'你好'到光標后面" />
<input onclick="TT.del(test,2)" type="button" value="刪除光標前2個字符" />
<input onclick="TT.del(test,-2)" type="button" value="刪除光標后2個字符" />
<input onclick="TT.sel(test,0,2)" type="button" value="選中字符0-2的位置" />
<input onclick="TT.selString(test,'mno')" type="button" value="選中字符'mno'的位置" />
<script type="text/javascript">// <![CDATA[
var test = document.getElementById('testlujun');
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
 },

 
 /*
  * 設(shè)置光標位置
  * @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
  * 重新設(shè)置 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;
 }

}
// ]]></script>

相關(guān)文章

  • 使用webpack搭建vue項目實現(xiàn)腳手架功能

    使用webpack搭建vue項目實現(xiàn)腳手架功能

    這篇文章主要介紹了使用webpack搭建vue項目實現(xiàn)腳手架功能,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友們下面隨著小編來一起學(xué)習(xí)學(xué)習(xí)吧
    2019-03-03
  • JavaScript數(shù)組和對象的復(fù)制

    JavaScript數(shù)組和對象的復(fù)制

    本篇文章主要介紹了JavaScript數(shù)組和對象的復(fù)制的相關(guān)知識。具有很好的參考價值。下面跟著小編一起來看下吧
    2017-03-03
  • Javascript基于OOP實實現(xiàn)探測器功能代碼實例

    Javascript基于OOP實實現(xiàn)探測器功能代碼實例

    這篇文章主要介紹了Javascript基于OOP實實現(xiàn)探測器功能代碼實例,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2020-08-08
  • 鼠標左鍵單擊沖突的問題解決方法(防止冒泡)

    鼠標左鍵單擊沖突的問題解決方法(防止冒泡)

    一個頁面實現(xiàn)了兩種右鍵菜單,當(dāng)鼠標左鍵單擊空白處時,右鍵菜單并不隱藏,下面為大家解決鼠標左鍵單擊沖突的問題
    2014-05-05
  • 對Layer彈窗使用及返回數(shù)據(jù)接收的實例詳解

    對Layer彈窗使用及返回數(shù)據(jù)接收的實例詳解

    今天小編就為大家分享一篇對Layer彈窗使用及返回數(shù)據(jù)接收的實例詳解,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2019-09-09
  • 詳解JS如何判斷對象上是否存在某個屬性

    詳解JS如何判斷對象上是否存在某個屬性

    判斷某一個對象里面是否存在某個屬性,是常見錯誤場景排查,但是你真的知道該如何使用嘛,本文為大家整理了常用的三種方法,希望對大家有所幫助
    2023-05-05
  • 在webstorm中配置less的方法詳解

    在webstorm中配置less的方法詳解

    這篇文章主要介紹了在webstorm中配置less的方法,本文通過圖文并茂的形式給大家介紹的非常詳細,對大家的學(xué)習(xí)或工作具有一定的參考借鑒價值,需要的朋友參考下吧
    2020-09-09
  • 詳解javascript中對數(shù)據(jù)格式化的思考

    詳解javascript中對數(shù)據(jù)格式化的思考

    本篇文章主要介紹了詳解javascript中對數(shù)據(jù)文本格式化的思考 ,具有一定的參考價值,有興趣的可以了解一下。
    2017-01-01
  • JavaScript設(shè)計模式之裝飾者模式實例詳解

    JavaScript設(shè)計模式之裝飾者模式實例詳解

    這篇文章主要介紹了JavaScript設(shè)計模式之裝飾者模式,結(jié)合實例形式較為詳細的分析了裝飾者模式的概念、原理及javascript定義、使用裝飾者模式的相關(guān)操作技巧,需要的朋友可以參考下
    2019-01-01
  • 微信小程序登錄時如何獲取input框中的內(nèi)容

    微信小程序登錄時如何獲取input框中的內(nèi)容

    這篇文章主要介紹了微信小程序登錄時如何獲取input框中的內(nèi)容,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,需要的朋友可以參考下
    2019-12-12

最新評論