javascript textarea MaxLength 属性的实现

ExpandedBlockStart.gif 代码

//  Keep user from entering more than maxLength characters
function  doKeyPress(obj, evt) {
    maxLength 
=  obj.getAttribute( " maxlength " );
    
var  e  =  window.event  ?  event.keyCode: evt.which;
    
if  ((e  ==   32 ||  (e  ==   13 ||  (e  >   47 )) {  // IE
         if  (maxLength  &&  (obj.value.length  >  maxLength  -   1 )) {
            
if  (window.event) {
                window.event.returnValue 
=   null ;
            } 
else  {
                evt.cancelDefault;
                
return   false ;
            }
        }
    }
}
function  doKeyUp(obj) {
    maxLength 
=  obj.getAttribute( " maxlength " );
    
if  (maxLength  &&  obj.value.length  >  maxLength) {
        obj.value 
=  obj.value.substr( 0 , maxLength);
    }
    sr 
=  obj.getAttribute( " ShowLength " );
    
if  (sr) {
//         alert((maxLength - obj.value.length));
        document.getElementById(sr).innerHTML  =   " 可填  " +  (maxLength  -  obj.value.length) + "  字 " ;
    }
}

//  Cancel default behavior and create a new paste routine
function  doPaste(obj) {
    maxLength 
=  obj.getAttribute( " maxlength " );
    
if  (maxLength) {
        
var  detect  =  navigator.userAgent.toLowerCase();
        
if  ((window.event)  &&  (detect.indexOf( " safari " +   1   ==   0 )) {  // IE
             var  oTR  =  obj.document.selection.createRange();
            
var  iInsertLength  =  maxLength  -  obj.value.length  +  oTR.text.length;
            
try  {
                
var  sData  =  window.clipboardData.getData( " Text " ).substr( 0 , iInsertLength);
                oTR.text 
=  sData;
            } 
catch (err) {}
            
if  (window.event) {  // IE
                window.event.returnValue  =   null ;
            } 
else  {
                
// not IE
                obj.value  =  obj.value.substr( 0 , maxLength);
                
return   false ;
            }
        }
    }
}

http://blog.offbeatmammal.com/post/2006/10/26/MaxLength-on-a-Textarea.aspx

转载于:https://www.cnblogs.com/jgjgjg23/archive/2010/11/03/1867751.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值