DIV CSS 佈局教程網

 DIV+CSS佈局教程網 >> 網頁腳本 >> JavaScript入門知識 >> JavaScript基礎知識 >> js限制文本框輸入長度兩種限制方式(長度、字節數)
js限制文本框輸入長度兩種限制方式(長度、字節數)
編輯:JavaScript基礎知識     
功能/特點
1.實時顯示可輸入的字數(字節數)
2.兩種限制方式(長度、字節數)
3.中文輸入法下可正常使用,無BUG
4.同一頁面可以使用多個,相互不干擾
limit.js
復制代碼 代碼如下:
function limit(){
var txtNote;//文本框
var txtLimit;//提示字數的input
var limitCount;//限制的字數
var isbyte;//是否使用字節長度限制(1漢字=2字符)
var txtlength;//到達限制時,字符串的長度
var txtByte;
this.init=function(){
txtNote=this.txtNote;
txtLimit=this.txtLimit;
limitCount=this.limitCount;
isbyte=this.isbyte;
txtNote.onkeydown=function(){wordsLimit()};txtNote.onkeyup=function(){wordsLimit()};
txtLimit.value=limitCount;
}
function wordsLimit(){
var noteCount=0;
if(isbyte){noteCount=txtNote.value.replace(/[^/x00-/xff]/g,"xx").length}else{noteCount=txtNote.value.length}
if(noteCount>limitCount){
if(isbyte){
txtNote.value=txtNote.value.substring(0,txtlength+Math.floor((limitCount-txtByte)/2));
txtByte=txtNote.value.replace(/[^/x00-/xff]/g,"xx").length;
txtLimit.value=limitCount-txtByte;
}else{
txtNote.value=txtNote.value.substring(0,limitCount);
txtLimit.value=0;
}
}else{
txtLimit.value=limitCount-noteCount;
}
txtlength=txtNote.value.length;//記錄每次輸入後的長度
txtByte=txtNote.value.replace(/[^/x00-/xff]/g,"xx").length;
}
}

頁面調用:
復制代碼 代碼如下:
<html>
<body>
<input id="txtNote" />
還可輸入<input type="text" id="txtCount" />個字符
</body>
<mce:script type="text/javascript"><!--
var lim=new limit();
lim.txtNote=document.getElementById("txtNote");
lim.txtLimit=document.getElementById("txtCount");
lim.limitCount=20;
lim.isbyte=true;
lim.init();
// --></mce:script>
</html>


文本框限制字符長度
復制代碼 代碼如下:
<INPUT onkeydown=if(event.keyCode==13)event.keyCode=9 onkeyup="value=value.replace(/[^0-9- ]/g,'');" maxLength=11 >

上面這樣寫只能限制輸入的一定是數字 和最大長度為11個字符 如何限制一定要輸入11位 不能少也不能多
------解決方案--------------------------------------------------------
你確定上面的寫法對嗎。。。測試怎麼通不過呢。。
不對嗎 測試那裡不對 這個現在只是限制輸入一定是數字和11個字符
------解決方案--------------------------------------------------------
復制代碼 代碼如下:
<INPUT onkeydown=if(event.keyCode==13)event.keyCode=9 onkeyup="value=value.replace(/[^0-9- ]/g,'');" maxLength=11 >

上面這樣寫只能限制輸入的一定是數字 和最大長度為11個字符 如何限制一定要輸入11位 不能少也不能多
------解決方案--------------------------------------------------------
復制代碼 代碼如下:
<INPUT onkeydown=if(event.keyCode==13)event.keyCode=9 onkeyup="value=value.replace(/[^0-9- ]/g,'');" maxLength=11 >

上面這樣寫只能限制輸入的一定是數字 和最大長度為11個字符 如何限制……
------解決方案--------------------------------------------------------
復制代碼 代碼如下:
if(document.form.mobile.value=="")
{
alert("您輸入錯誤");
document.forma.mobile.focus();
return false;
}
else
{
if(!/^\d{11}$.test(document.form.mobile.value))
{alert("您輸入數字的位數不對");
document.forma.mobile.focus();
return false;
}
}

不知道這樣行不行。。。
------解決方案--------------------------------------------------------
HTML code
復制代碼 代碼如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html>
<head>
<title>控制textarea的字符個數</title>
<style>
<!--
form{
padding:0px;
margin:0px;
font:14px Arial;
}
input.txt{ /* 文本框單獨設置 */
border: 1px inset #00008B;
background-color: #ADD8E6;
}
input.btn{ /* 按鈕單獨設置 */
color: #00008B;
background-color: #ADD8E6;
border: 1px outset #00008B;
padding: 1px 2px 1px 2px;
}
-->
</style>
<script language="javascript">
function LessThan(oTextArea){
//返回文本框字符個數是否符號要求的boolean值
return oTextArea.value.length < oTextArea.getAttribute("maxlength");
}
</script>
</head>
<body>
<form method="post" name="myForm1" action="addInfo.aspx">
<p><label for="name">請輸入您的姓名:</label>
<input type="text" name="name" id="name" class="txt" value="姓名" maxlength="10"></p>
<p><label for="comments">我要留言:</label><br>
<textarea name="comments" id="comments" cols="40" rows="4" maxlength="50" onkeypress="return LessThan(this);"></textarea></p>
<p><input type="submit" name="btnSubmit" id="btnSubmit" value="Submit" class="btn">
<input type="reset" name="btnReset" id="btnReset" value="Reset" class="btn"></p>
</form>
</body>
</html>

------解決方案--------------------------------------------------------
HTML code
復制代碼 代碼如下:
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<title>電話號碼檢測 </title>
<meta name="Generator" content="EditPlus">
<meta name="Author" content="Dsmart">
<meta name="Keywords" content="">
<meta name="Description" content="">
</head>
<body>
電話號碼:<input id ="phone" type="value" onblur="checkPhone()"/>
<script type="text/javascript">
function checkPhone(){
var phone = document.getElementById("phone").value;
if(phone == ""){
alert("請輸入號碼");
}else if(!(/^\d{11}$/g.test(phone))){//限制輸入11整數
//}else if(!(/^13\d{9}$/g.test(phone)||(/^15[0-35-9]\d{8}$/g.test(phone))|| (/^18[05-9]\d{8}$/g.test(phone)))){
//用於檢測用戶輸入的手機號碼是否正確 驗證13系列和150-159(154除外)、180、185、186、187、188、189幾種號碼,長度11位
alert("請輸入11整數");
}else{
alert("ok");
}
}
</script>
</body>
</html>

------解決方案--------------------------------------------------------
復制代碼 代碼如下:
<INPUT onkeydown=if(event.keyCode==13)event.keyCode=9 onkeyup="value=value.replace(/[^0-9- ]/g,'');" maxLength=11 >

上面這樣寫只能限制輸入的一定是數字 和最大長度為11個字符 如何限制……
這樣是可以有個提示,但並沒起到限制作用,,當輸入少於11位 還是可以提交的,這個是不是要用js來控制的呢
XML學習教程| jQuery入門知識| AJAX入門| Dreamweaver教程| Fireworks入門知識| SEO技巧| SEO優化集錦|
Copyright © DIV+CSS佈局教程網 All Rights Reserved