JAVASCRIPT应用篇(5)--设置TEXTAREA的MAXLENGTH属性

  5554人阅读  评论(1)  收藏  举报

标准的DHTML文档中TEXTAREA的MAXLENGTH属性默认情况下不起作用,只有当事件发生时才起作用

如下:http://spiderscript.net/site/spiderscript/examples/ex_textarea_maxlength.asp

但TEXT中有且起作用<input type="text" maxlength="20">,

 

那么在TEXTAREA中怎么实现输入内容不能超过多少个字符呢。

方法1、如果只需要截取多少个字符的内容,则可以:

<textarea οnkeyup="this.value = this.value.slice(0, 80)"></textarea>

<textarea οnkeyup="this.value = this.value.substring(0, 80)"></textarea>

方法2、

<script type="text/javascript">
function ismaxlength(obj){
var mlength=obj.getAttribute? parseInt(obj.getAttribute("maxlength")) : ""
if (obj.getAttribute && obj.value.length>mlength)
obj.value=obj.value.substring(0,mlength)
}
</script>

<textarea maxlength="40" οnkeyup="return ismaxlength(this)"></textarea>

这个方法采用截断法,输入到最后一个字符的时候如果再输入则会显示光标闪烁。但可以解决使用CTRL+C复制过来的长度限制问题,但如果用鼠标复制过来的不还是不行。

方法3、这个方法直接判断输入的长度

<script language="javascript" type="text/javascript">

<!--

function imposeMaxLength(Object, MaxLen)

{

return (Object.value.length <MaxLen);

}

-->

</script>

<textarea name="myName" οnkeypress="return imposeMaxLength(this, 15);" ></textarea>

当输入内容大于15时因为返回为false所以这个实现不会显示光标闪烁的问题,但没有解决复制过来的长度限制问题即复制过来的内容可以超过最大长度限制

注意这个帖子里使用的情况如:http://psacake.com/web/js.asp

return (Object.value.length <=MaxLen);但我测试发现当输入字节数=maxlen时还可以输入一个字符,所以我改成 return (Object.value.length <MaxLen);

方法4、其实方法4是方法2与方法3的基础上进一步优化。客观的说方法2与方法3都只做了一部分工作

看下面链接:http://www.codingforums.com/showthread.php?t=2224

  
  
  1. <mce:script language="javascript" type="text/javascript"><!--  
  2. function textlen(x,y){  
  3.   var thelength = x.value.length;  
  4.   window.status=thelength+' of '+y+' maximum characters.';  
  5. }  
  6.   
  7. function maxtext(x,y){  
  8. tempstr = x.value  
  9.   if(tempstr.length>y){  
  10.     x.value = tempstr.substring(0,y);  
  11.   }  
  12.   textlen(x,y);  
  13. }  
  14. // --></mce:script>  
  15.   
  16. <form name="myform">  
  17.      <textarea      name="mytextarea"   
  18.                            cols="45"   
  19.                            rows="3"   
  20.                            wrap="virtual"   
  21.                            onkeypress="return(this.value.length<20)"  
  22.                            onkeydown="textlen(this,20)"   
  23.                            onkeyup="textlen(this,20)"   
  24.                            onblur="maxtext(this,20)"  
  25.      >  
上面的方法在原来的基础上加了onblur事件,这主要用于处理当用户不是采用输入而是通过复制粘贴方法来完成文本的转入时的问题。 实际就是方法2与方法3的结合版。 以下是我为TextArea增加并利用maxlength属性及结合上例的结果: 
<html>
<head>
<script type="text/javascript">
function ismaxlength(obj){
var mlength=obj.getAttribute? parseInt(obj.getAttribute("maxlength")) : ""
if (obj.getAttribute && obj.value.length>mlength)
alert('该文本框允许输入最大长度为'+mlength+"个字符,超出内容将会被截断")
obj.value=obj.value.substring(0,mlength)
}
function imposeMaxLength(obj)
{
var mlength=obj.getAttribute? parseInt(obj.getAttribute("maxlength")) : ""
return (obj.value.length <mlength);
}
</script>
</head>
<body>
<form name="myform">
<textarea maxlength="5" οnkeypress="return imposeMaxLength(this)" οnblur="ismaxlength(this)"></textarea>
</form>
</body>
</html>

 


   对于些问题的其它主要解决方法可见下面链接:
利用JQUERY框架实现:http://viralpatel.net/blogs/2008/12/set-maxlength-of-textarea-input-using-jquery-javascript.html
http://www.codingforums.com/showthread.php?t=2224
http://www.insidedhtml.com/ie5/htc/ts08/page2.asp
http://inmyexperience.com/archives/000327.shtml
 
 
http://blog.csdn.net/luweifeng1983/article/details/3935040
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值