textarea稱文本域,又稱文本區,即有滾動條的多行文本輸入控件,在網頁的提交表單中常常用到。與單行文本框text控件不一樣,它不能經過maxlength屬性來限制字數,爲此必須尋求其餘方法來加以限制以達到預設的需求。 html
一般的作法就是使用#腳本語言來實現對textarea文本域的字數輸入限制,簡單而實用。假設咱們有一個id爲 txta1 的textarea文本區,咱們能夠經過如下代碼限制它的鍵盤輸入字數爲10個字(漢字或其餘小角字符): less
<script language="#" type="text/ecmascript"> window.onload = function() { document.getElementById('txta1').onkeydown = function() { if(this.value.length >= 10) event.returnValue = false; } } </script>
它的原理是經過對keydown(鍵盤鍵位按下)事件對指定id號的文本區進行監測,能夠想象,它只能限制鍵盤輸入,若是用戶經過鼠標右鍵粘貼剪切板中的文本,它沒法控制字數。 ecmascript
經過鍵盤輸入,以上文本區只能輸入10個字。可是,咱們的目的並無達到!請隨便複製一些文本,試着用鼠標右鍵粘貼,看看發生了什麼。 測試
你能夠在網上找到相似上述的其餘JS腳本,它們無論多麼優秀,其原理都是同樣的,經過對keydown、keyup或keypress之類的鍵盤鍵位操做事件來監控文本區的輸入,沒法防止鼠標右鍵的粘貼,爲此,若是必定要真正地限制textarea的字數,咱們還得爲網頁加另外一把鎖——禁用鼠標右鍵,這無疑得付出額外的開銷,同時也多是網頁製做者不必定願意作的。其實,還有一個更簡單的方法,使用onpropertychange屬性。 this
onpropertychange能夠用來判斷預約元素的value值,當元素的value值發生變化時判斷事件就會被觸發,僅關心被監測元素的value值,避開了輸入的來源,從而能夠比較理想地達成咱們的限制字數這一目的。它屬於JS範疇,能夠在表單方框區表明中嵌套使用,如下是代碼和效果樣式,能夠像上面那樣測試輸入,你會發現它真正達到目的:無論用什麼方式輸入,它只能輸入100個字(漢字或其餘小解符號): spa
代碼: code
<textarea onpropertychange="if(value.length>100) value=value.substr(0,100)" class="smallArea" cols="60" name="txta" rows="8"></textarea>
另一種方法實現textarea限制輸入字數(包含中文只能輸入10個,全ASCII碼可以輸入20個) htm
<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> 剩餘字數: <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 裏面提示輸入最大字節數。 例如:<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>
從網上摘抄來的,但願對你們有幫助哦~~ ip