对多行文本框限制长度
下面是完整的代码,支持中文,支持粘贴,偶从网上copy的
 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
 <html>
<html>
 <head>
<head>
 <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312">
 <title>test</title>
<title>test</title>
 <script language=javascript>
<script language=javascript> 
 <!--
<!-- 

 String.prototype.len=function(){
String.prototype.len=function(){ 
 return this.replace(/[^\x00-\xff]/g,"**").length;
return this.replace(/[^\x00-\xff]/g,"**").length; 
 }
} 

 //Set maxlength for multiline TextBox
//Set maxlength for multiline TextBox 
 function setMaxLength(object,length)
function setMaxLength(object,length) 
 {
{ 
 var result = true;
var result = true; 
 var controlid = document.selection.createRange().parentElement().id;
var controlid = document.selection.createRange().parentElement().id; 
 var controlValue = document.selection.createRange().text;
var controlValue = document.selection.createRange().text; 
 if (controlid == object.id && controlValue != "")
if (controlid == object.id && controlValue != "") 
 {
{ 
 result = true;
result = true; 
 }
} 
 else if (object.value.len() >= length)
else if (object.value.len() >= length) 
 {
{ 
 result = false;
result = false; 
 }
} 
 if (window.event)
if (window.event) 
 {
{ 
 window.event.returnValue = result;
window.event.returnValue = result; 
 return result;
return result; 
 }
} 
 }
} 

 //Check maxlength for multiline TextBox when paste
//Check maxlength for multiline TextBox when paste 
 function limitPaste(object,length)
function limitPaste(object,length) 
 {
{ 
 var tempLength = 0;
var tempLength = 0; 
 if(document.selection)
if(document.selection) 
 {
{ 
 if(document.selection.createRange().parentElement().id == object.id)
if(document.selection.createRange().parentElement().id == object.id) 
 {
{ 
 tempLength = document.selection.createRange().text.len();
tempLength = document.selection.createRange().text.len(); 
 }
} 
 }
} 
 var tempValue = window.clipboardData.getData("Text");
var tempValue = window.clipboardData.getData("Text"); 
 tempLength = object.value.len() + tempValue.len() - tempLength;
tempLength = object.value.len() + tempValue.len() - tempLength; 
 if (tempLength > length)
if (tempLength > length) 
 {
{ 
 tempLength -= length;
tempLength -= length; 
 var tt="";
var tt=""; 
 for(var i=0;i<tempValue.len()-tempLength;i++)
for(var i=0;i<tempValue.len()-tempLength;i++) 
 {
{ 
 if(tt.len()<(tempValue.len()-tempLength))
if(tt.len()<(tempValue.len()-tempLength)) 
 tt=tempValue.substr(0,i+1);
tt=tempValue.substr(0,i+1); 
 else
else 
 break;
break; 
 }
} 
 tempValue=tt;
tempValue=tt; 
 window.clipboardData.setData("Text", tempValue);
window.clipboardData.setData("Text", tempValue); 
 }
} 

 window.event.returnValue = true;
window.event.returnValue = true; 
 }
} 

 //-->
//--> 
 </script>
</script> 

 </head>
</head>

 <body>
<body>
 <form name="form1" method="post" action="">
<form name="form1" method="post" action="">
 <textarea name="textarea" onkeypress="setMaxLength(this,10);" onpaste="limitPaste(this, 10)"></textarea>
  <textarea name="textarea" onkeypress="setMaxLength(this,10);" onpaste="limitPaste(this, 10)"></textarea>
 </form>
</form>
 </body>
</body>
 </html>
</html>

 <!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN"> <html>
<html> <head>
<head> <meta http-equiv="Content-Type" content="text/html; charset=gb2312">
<meta http-equiv="Content-Type" content="text/html; charset=gb2312"> <title>test</title>
<title>test</title> <script language=javascript>
<script language=javascript>  <!--
<!-- 
 String.prototype.len=function(){
String.prototype.len=function(){  return this.replace(/[^\x00-\xff]/g,"**").length;
return this.replace(/[^\x00-\xff]/g,"**").length;  }
} 
 //Set maxlength for multiline TextBox
//Set maxlength for multiline TextBox  function setMaxLength(object,length)
function setMaxLength(object,length)  {
{  var result = true;
var result = true;  var controlid = document.selection.createRange().parentElement().id;
var controlid = document.selection.createRange().parentElement().id;  var controlValue = document.selection.createRange().text;
var controlValue = document.selection.createRange().text;  if (controlid == object.id && controlValue != "")
if (controlid == object.id && controlValue != "")  {
{  result = true;
result = true;  }
}  else if (object.value.len() >= length)
else if (object.value.len() >= length)  {
{  result = false;
result = false;  }
}  if (window.event)
if (window.event)  {
{  window.event.returnValue = result;
window.event.returnValue = result;  return result;
return result;  }
}  }
} 
 //Check maxlength for multiline TextBox when paste
//Check maxlength for multiline TextBox when paste  function limitPaste(object,length)
function limitPaste(object,length)  {
{  var tempLength = 0;
var tempLength = 0;  if(document.selection)
if(document.selection)  {
{  if(document.selection.createRange().parentElement().id == object.id)
if(document.selection.createRange().parentElement().id == object.id)  {
{  tempLength = document.selection.createRange().text.len();
tempLength = document.selection.createRange().text.len();  }
}  }
}  var tempValue = window.clipboardData.getData("Text");
var tempValue = window.clipboardData.getData("Text");  tempLength = object.value.len() + tempValue.len() - tempLength;
tempLength = object.value.len() + tempValue.len() - tempLength;  if (tempLength > length)
if (tempLength > length)  {
{  tempLength -= length;
tempLength -= length;  var tt="";
var tt="";  for(var i=0;i<tempValue.len()-tempLength;i++)
for(var i=0;i<tempValue.len()-tempLength;i++)  {
{  if(tt.len()<(tempValue.len()-tempLength))
if(tt.len()<(tempValue.len()-tempLength))  tt=tempValue.substr(0,i+1);
tt=tempValue.substr(0,i+1);  else
else  break;
break;  }
}  tempValue=tt;
tempValue=tt;  window.clipboardData.setData("Text", tempValue);
window.clipboardData.setData("Text", tempValue);  }
} 
 window.event.returnValue = true;
window.event.returnValue = true;  }
} 
 //-->
//-->  </script>
</script> 
 </head>
</head>
 <body>
<body> <form name="form1" method="post" action="">
<form name="form1" method="post" action=""> <textarea name="textarea" onkeypress="setMaxLength(this,10);" onpaste="limitPaste(this, 10)"></textarea>
  <textarea name="textarea" onkeypress="setMaxLength(this,10);" onpaste="limitPaste(this, 10)"></textarea> </form>
</form> </body>
</body> </html>
</html> 
                    
                     
                    
                 
                    
                


 String.prototype.len
String.prototype.len 
                
            
         
         浙公网安备 33010602011771号
浙公网安备 33010602011771号