js限制输入框可输入字节数

本文介绍了一种使用JavaScript实现的限制HTML输入框中字节数的方法。通过计算字符串的字节长度并监视输入框的值变化,确保用户输入的内容不超过预设的最大字节数。适用于需要控制输入长度的场景。

看看效果:

 

  • 可输入5个字节:
  • 可输入6个字节:
  • 可输入7个字节:
  • 可输入n个字节:

代码如下:(本来基于原型封装了一下,发现完全在增加代码量,又改回来了)

 

感谢sparks345提出粘贴时的问题

这样的话,只能多加几个事件onpropertychange,oninput, obj.watch("value",function(id,oval,nval){})

具体可以看这里,跟踪input值改变兼容处理

 

ExpandedBlockStart.gif code here
<! DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd" >
< html  xmlns ="http://www.w3.org/1999/xhtml" >     
< head >
    
< title > 限制输入字节数 </ title >
    
< meta  name ="author"  content ="sohighthesky" />
    
< style  type ="text/css" >
        #div1 
{ width : 500px ; margin : 20px auto ; }
        #div1 ul 
{ list-style-type : decimal ; line-height : 25px ; }
    
</ style >
</ head >  
< body >
    
< div  id ="div1" >
        
< ul >
            
< li > 可输入5个字节: < input  type ="text"  id ="txt1"  value ="你好e" /></ li >
            
< li > 可输入6个字节: < input  type ="text"  id ="txt2"  value ="hello," /></ li >
            
< li > 可输入7个字节: < input  type ="text"  id ="txt3"  value =",he" /></ li >
            
< li > 可输入n个字节: < input  type ="text"  id ="txt4" /></ li >
        
</ ul >
    
</ div >
</ body >
< script  type ="text/javascript" >
/* !
 *author:sohighthesky
 *Date:2010-1-16
 
*/
! function (){
var  len = function (s){ // 获取字符串的字节长度
    s = String(s);
    
return  s.length + (s.match( / [^\x00-\xff] / g)  || "" ).length; // 加上匹配到的全角字符长度
},
limitDo
= function (limit){
    
var  val = this .value;
    
if (len(val) > limit) {
        
// val=val.substr(0,limit);
         while (len(val = val.substr( 0 ,val.length - 1 )) > limit);
        
this .value = val;
    }
},$
= function (id){ return   typeof (id) === ' string ' ? document.getElementById(id):id;};

$(
" txt1 " ).onkeyup = function (){limitDo.call( this , 5 )};
$(
" txt2 " ).onkeyup = function (){limitDo.call( this , 6 )};
$(
" txt3 " ).onkeyup = function (){limitDo.call( this , 7 )};
}();
</ script >
</ html >

 

 

转载于:https://www.cnblogs.com/sohighthesky/archive/2010/01/16/input-maxsize-limit.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值