textarea中限制輸入字元長度(實用版)
textarea稱文字域,又稱文字區,即有滾動條的多行文字輸入控制元件,在網頁的提交表單中經常用到。與單行文字框text控制元件不同,它不能通過maxlength屬性來限制字數,為此必須尋求其他方法來加以限制以達到預設的需求。
通常的做法就是使用#指令碼語言來實現對textarea文字域的字數輸入限制,簡單而實用。假設我們有一個id為 txta1 的textarea文字區,我們可以通過以下程式碼限制它的鍵盤輸入字數為10個字(漢字或其他小角字元):
<script language="#" type="text/ecmascript">
window.onload = function()
{
document.getElementById('txta1').onkeydown = function()
{
if(this.value.length >= 10)
event.returnValue = false;
}
}
</script>
它的原理是通過對keydown(鍵盤鍵位按下)事件對指定id號的文字區進行監測,可以想象,它只能限制鍵盤輸入,如果使用者通過滑鼠右鍵貼上剪下板中的文字,它無法控制字數。
通過鍵盤輸入,以上文字區只能輸入10個字。但是,我們的目的並沒有達到!請隨便複製一些文字,試著用滑鼠右鍵貼上,看看發生了什麼。
你可以在網上找到類似上述的其他JS指令碼,它們不管多麼優秀,其原理都是一樣的,通過對keydown、keyup或keypress之類的鍵盤鍵位操作事件來監控文字區的輸入,無法防止滑鼠右鍵的貼上,為此,如果一定要真正地限制textarea的字數,我們還得為網頁加另一把鎖——禁用滑鼠右鍵,這無疑得付出額外的開銷,同時也可能是網頁製作者不一定願意做的。其實,還有一個更簡單的方法,使用onpropertychange屬性。
onpropertychange可以用來判斷預定元素的value值,當元素的value值發生變化時判斷事件就會被觸發,僅關心被監測元素的value值,避開了輸入的來源,從而可以比較理想地達成我們的限制字數這一目的。它屬於JS範疇,可以在表單方框區代表中巢狀使用,以下是程式碼和效果樣式,可以像上面那樣測試輸入,你會發現它真正達到目的:不管用什麼方式輸入,它只能輸入100個字(漢字或其他小解符號):
程式碼:
<textarea onpropertychange="if(value.length>100) value=value.substr(0,100)" class="smallArea" cols="60" name="txta" rows="8"></textarea>
當然,為了更為保險,處理表單資料的後臺指令碼程式還應該對提交來的資料進行再一次的檢測,如果字數超出預設的數量則進行相應處理,這樣才達到真正限制字數的目的
另外一種方法實現textarea限制輸入字數(包含中文只能輸入10個,全ASCII碼能夠輸入20個)
<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>