textarea不能通過(guò)maxlength屬性來(lái)限制字?jǐn)?shù)的解決方法
textarea稱文本域,又稱文本區(qū),即有滾動(dòng)條的多行文本輸入控件,在網(wǎng)頁(yè)的提交表單中經(jīng)常用到。與單行文本框text控件不同,它不能通過(guò)maxlength屬性來(lái)限制字?jǐn)?shù),為此必須尋求其他方法來(lái)加以限制以達(dá)到預(yù)設(shè)的需求。
通常的做法就是使用#腳本語(yǔ)言來(lái)實(shí)現(xiàn)對(duì)textarea文本域的字?jǐn)?shù)輸入限制,簡(jiǎn)單而實(shí)用。假設(shè)我們有一個(gè)id為 txta1 的textarea文本區(qū),我們可以通過(guò)以下代碼限制它的鍵盤(pán)輸入字?jǐn)?shù)為10個(gè)字(漢字或其他小角字符):
<script language="#" type="text/ecmascript"> window.onload = function() { document.getElementById('txta1').onkeydown = function() { if(this.value.length >= 10) event.returnValue = false; } } </script>
它的原理是通過(guò)對(duì)keydown(鍵盤(pán)鍵位按下)事件對(duì)指定id號(hào)的文本區(qū)進(jìn)行監(jiān)測(cè),可以想象,它只能限制鍵盤(pán)輸入,如果用戶通過(guò)鼠標(biāo)右鍵粘貼剪切板中的文本,它無(wú)法控制字?jǐn)?shù)。
通過(guò)鍵盤(pán)輸入,以上文本區(qū)只能輸入10個(gè)字。但是,我們的目的并沒(méi)有達(dá)到!請(qǐng)隨便復(fù)制一些文本,試著用鼠標(biāo)右鍵粘貼,看看發(fā)生了什么。
你可以在網(wǎng)上找到類似上述的其他JS腳本,它們不管多么優(yōu)秀,其原理都是一樣的,通過(guò)對(duì)keydown、keyup或keypress之類的鍵盤(pán)鍵 位操作事件來(lái)監(jiān)控文本區(qū)的輸入,無(wú)法防止鼠標(biāo)右鍵的粘貼,為此,如果一定要真正地限制textarea的字?jǐn)?shù),我們還得為網(wǎng)頁(yè)加另一把鎖——禁用鼠標(biāo)右 鍵,這無(wú)疑得付出額外的開(kāi)銷,同時(shí)也可能是網(wǎng)頁(yè)制作者不一定愿意做的。其實(shí),還有一個(gè)更簡(jiǎn)單的方法,使用onpropertychange屬性。
onpropertychange可以用來(lái)判斷預(yù)定元素的value值,當(dāng)元素的value值發(fā)生變化時(shí)判斷事件就會(huì)被觸發(fā),僅關(guān)心被監(jiān)測(cè)元素的 value值,避開(kāi)了輸入的來(lái)源,從而可以比較理想地達(dá)成我們的限制字?jǐn)?shù)這一目的。它屬于JS范疇,可以在表單方框區(qū)代表中嵌套使用,以下是代碼和效果樣 式,可以像上面那樣測(cè)試輸入,你會(huì)發(fā)現(xiàn)它真正達(dá)到目的:不管用什么方式輸入,它只能輸入100個(gè)字(漢字或其他小解符號(hào)):
代碼:
<textarea onpropertychange="if(value.length>100) value=value.substr(0,100)" class="smallArea" cols="60" name="txta" rows="8"></textarea>
當(dāng)然,為了更為保險(xiǎn),處理表單數(shù)據(jù)的后臺(tái)腳本程序還應(yīng)該對(duì)提交來(lái)的數(shù)據(jù)進(jìn)行再一次的檢測(cè),如果字?jǐn)?shù)超出預(yù)設(shè)的數(shù)量則進(jìn)行相應(yīng)處理,這樣才達(dá)到真正限制字?jǐn)?shù)的目的。(完)
另外一種方法實(shí)現(xiàn)textarea限制輸入字?jǐn)?shù)(包含中文只能輸入10個(gè),全ASCII碼能夠輸入20個(gè))
<script> function check() { var regC = /[^ -~]+/g; var regE = /\D+/g; var str = t1.value; if (regC.test(str)){ t1.value = t1.value.substr(0,10); } if(regE.test(str)){ t1.value = t1.value.substr(0,20); } } </script> <textarea maxlength="10" id="t1" onkeyup="check();"> </textarea>
還有一種方式:
function textCounter(field, maxlimit) { if (field.value.length > maxlimit){ field.value = field.value.substring(0, maxlimit); }else{ document.upbook.remLen.value = maxlimit - field.value.length; } }
<textarea name=words cols=19 rows=5 class=input1 onPropertyChange= "textCounter(upbook.words, 50) "> textarea> 剩余字?jǐn)?shù): <input name=remLen type=text id= "remLen " style= "background-color: #D4D0C8; border: 0; color: red " value=50 size=3 maxlength=3 readonly>
function LimitTextArea(field){ maxlimit=200; if (field.value.length > maxlimit) field.value = field.value.substring(0, maxlimit); }
<textarea cols=50 rows=10 name="comment" id="commentarea" onKeyDown="LimitTextArea(this)" onKeyUp="LimitTextArea(this)" onkeypress="LimitTextArea(this)" ></textarea>
title="The textarea width must less than 300 characters." 放在textarea 里面提示輸入最大字節(jié)數(shù)。
例如:
<textarea title="The textarea width must less than 300 characters." cols=50 rows=10 name="comment" id="commentarea" onKeyDown="LimitTextArea(this)" onKeyUp="LimitTextArea(this)" onkeypress="LimitTextArea(this)" ></textarea>
相關(guān)文章
jquery動(dòng)態(tài)添加刪除div 具體實(shí)現(xiàn)
這篇文章介紹了jquery動(dòng)態(tài)添加刪除div實(shí)現(xiàn)代碼,有需要的朋友可以參考一下2013-07-07js實(shí)現(xiàn)數(shù)組去重、判斷數(shù)組以及對(duì)象中的內(nèi)容是否相同
數(shù)組去重,判斷數(shù)組、對(duì)象中的內(nèi)容是否相同等等,在接下來(lái)的文章中使用js來(lái)簡(jiǎn)單實(shí)現(xiàn)下,感興趣的朋友不要錯(cuò)過(guò)2013-11-11javascript避免數(shù)字計(jì)算精度誤差的方法詳解
本篇文章主要是對(duì)javascript避免數(shù)字計(jì)算精度誤差的方法進(jìn)行了介紹,需要的朋友可以過(guò)來(lái)參考下,希望對(duì)大家有所幫助2014-03-03正則中的回溯定義與用法分析【JS與java實(shí)現(xiàn)】
這篇文章主要介紹了正則中的回溯定義與用法,結(jié)合實(shí)例形式分析了回溯的概念、功能并提供了JS與java實(shí)現(xiàn)方法,需要的朋友可以參考下2016-12-12Javascript實(shí)現(xiàn)帶關(guān)閉按鈕的網(wǎng)頁(yè)漂浮廣告代碼
帶有關(guān)閉功能的漂浮圖片的實(shí)現(xiàn)方法有很多,下面為大家介紹下使用Javascript是如何實(shí)現(xiàn)的,喜歡的額朋友可以了解下2014-01-01關(guān)閉頁(yè)面window.location事件未執(zhí)行的原因及解決方法
這篇文章主要介紹了關(guān)閉頁(yè)面window.location事件未執(zhí)行的原因及解決方法,需要的朋友可以參考下2014-09-09JavaScript 繼承 封裝 多態(tài)實(shí)現(xiàn)及原理詳解
這篇文章主要介紹了JavaScript 繼承 封裝 多態(tài)實(shí)現(xiàn)及原理詳解,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2019-07-07JS簡(jiǎn)單實(shí)現(xiàn)String轉(zhuǎn)Date的方法
這篇文章主要介紹了JS簡(jiǎn)單實(shí)現(xiàn)String轉(zhuǎn)Date的方法,涉及JavaScript字符串與日期相互轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2016-03-03