亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

js操作textarea 常用方法總結(jié)

 更新時(shí)間:2012年12月03日 15:52:09   作者:  
在DOM里面操作textarea里面的字符,是比較麻煩的,本文將介紹一種比較簡(jiǎn)單的方法,需要的朋友可以參考下
在DOM里面操作textarea里面的字符,是比較麻煩的。
于是我有這個(gè)封裝分享給大家,測(cè)試過(guò)IE6,8, firefox ,chrome, opera , safari。兼容沒(méi)問(wèn)題。
注意:在firefox下 添加字符串的時(shí)候有個(gè)bug 就是scrollTop 會(huì)等于0,當(dāng)然解決了,但是不夠完美。如果有高手也研究過(guò),麻煩指點(diǎn)下。
復(fù)制代碼 代碼如下:

var TT = {
/*
* 獲取光標(biāo)位置
* @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è)置光標(biāo)位置
* @Method setCursorPosition
* @param t element
* @param p number
* @return
*/
setCursorPosition:function(t, p){
this.sel(t,p,p);
},
/*
* 插入到光標(biāo)后面
* @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)
};
},
/*
* 刪除光標(biāo) 前面或者后面的 n 個(gè)字符
* @Method del
* @param t element
* @param n number n>0 后面 n<0 前面
* @return
* 重新設(shè)置 value 的時(shí)候 scrollTop 的值會(huì)被清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();
}
},
/*
* 選中一個(gè)字符串
* @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;
}
}

相關(guān)文章

  • JavaScript中展開(kāi)運(yùn)算符及應(yīng)用的實(shí)例代碼

    JavaScript中展開(kāi)運(yùn)算符及應(yīng)用的實(shí)例代碼

    這篇文章主要介紹了JavaScript中展開(kāi)運(yùn)算符及應(yīng)用的實(shí)例代碼,本文給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2021-01-01
  • JavaScript調(diào)用堆棧及setTimeout使用方法深入剖析

    JavaScript調(diào)用堆棧及setTimeout使用方法深入剖析

    Javascript中會(huì)經(jīng)常用到setTimeout來(lái)推遲一個(gè)函數(shù)的執(zhí)行并且會(huì)在執(zhí)行到這句話后延遲1秒鐘來(lái)彈出alert窗口,接下來(lái)將介紹一下JavaScript調(diào)用堆棧和setTimeout用法,感興趣的你可不要錯(cuò)過(guò)了哈
    2013-02-02
  • 基于javascript如何傳遞特殊字符

    基于javascript如何傳遞特殊字符

    在 JavaScript 中使用反斜杠來(lái)向文本字符串添加特殊字符,下面通過(guò)本篇文章給大家介紹javascript如何傳遞特殊字符,對(duì)js傳遞特殊字符相關(guān)內(nèi)容感興趣的朋友一起學(xué)習(xí)吧
    2015-11-11
  • javascript函數(shù)報(bào)Uncaught?ReferenceError:?XXX?is?not?defined

    javascript函數(shù)報(bào)Uncaught?ReferenceError:?XXX?is?not?define

    本文主要介紹了javascript函數(shù)報(bào)Uncaught?ReferenceError:?XXX?is?not?defined,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧
    2023-07-07
  • JavaScript中Object的常用方法總結(jié)

    JavaScript中Object的常用方法總結(jié)

    這篇文章主要為大家整理了7個(gè)JavaScript中Object的常用方法的使用,文中的示例代碼講解詳細(xì),對(duì)我們掌握J(rèn)avaScript有一點(diǎn)的幫助,感興趣的可以了解一下
    2023-02-02
  • JS小功能(offsetLeft實(shí)現(xiàn)圖片滾動(dòng)效果)實(shí)例代碼

    JS小功能(offsetLeft實(shí)現(xiàn)圖片滾動(dòng)效果)實(shí)例代碼

    這篇文章主要介紹了offsetLeft實(shí)現(xiàn)圖片滾動(dòng)效果實(shí)例代碼,有需要的朋友可以參考一下
    2013-11-11
  • 一個(gè)鼠標(biāo)移動(dòng)滑出層效果的實(shí)現(xiàn)代碼

    一個(gè)鼠標(biāo)移動(dòng)滑出層效果的實(shí)現(xiàn)代碼

    一個(gè)鼠標(biāo)移動(dòng)滑出層的代碼,根據(jù)網(wǎng)上的視頻教程學(xué)習(xí)的,這也算是第一次練手吧,鼠標(biāo)靠近復(fù)選框的時(shí)候,就會(huì)顯示出一個(gè)層,移開(kāi)則消失。
    2011-08-08
  • Jquery 常用方法一覽表(集合)

    Jquery 常用方法一覽表(集合)

    之前腳本之家發(fā)過(guò)相關(guān)的文章,這里又是一篇關(guān)于jquery常用方法的收集整理,我們給放到一起,學(xué)習(xí)jquery的朋友可以參考下。
    2010-03-03
  • 微信小程序?qū)崿F(xiàn)登錄注冊(cè)tab切換效果

    微信小程序?qū)崿F(xiàn)登錄注冊(cè)tab切換效果

    這篇文章主要為大家詳細(xì)介紹了微信小程序?qū)崿F(xiàn)登錄注冊(cè)切換效果,簡(jiǎn)易版tab切換效果,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2018-11-11
  • js中值引用和地址引用實(shí)例分析

    js中值引用和地址引用實(shí)例分析

    這篇文章主要介紹了js中值引用和地址引用,結(jié)合實(shí)例形式分析了javascript值引用和地址引用相關(guān)原理、用法及操作注意事項(xiàng),需要的朋友可以參考下
    2019-06-06

最新評(píng)論