【www.gdgbn.com--jquery】

jqyery与网页特效 限制字符输入数功能


<script>
/*******************************
 * @author mr.think
 * @author blog http://www.111cn.net/
 * @2010.09.07
 * @可自由转载及使用,但请注明版权归属
 *******************************/
//原生javascript版本
window.onload=function(){
 var js=document.getelementbyid("js");//获取文本域
 var info=document.getelementsbytagname("p")[0];//获取要插入提示信息的元素
 var submit=info.getelementsbytagname("input")[0];//获取提交按钮
 var max=js.getattribute("maxlength");//获取限制输入的最大长度
 var tips教程=document.createelement("span");//新建一个提示span
 var val,cur,count,warn;
 submit.disabled=true;//默认不可提交
 tips.innerhtml="你还可以输入"+max+"个字符[不区分中英文字符数]";
 if(max){
  js.onkeyup=js.onchange=function(){
   submit.disabled=false;
   if(info.lastchild.nodename!="span") info.appendchild(tips);//避免每次弹起都会插入一条提示信息
   count=info.getelementsbytagname("em")[0];//根据输入数字变换区
   warn=info.getelementsbytagname("font")[0];//副标题
   val=this.value;
   cur=val.length;
//   for(var i=0;i //    if(val.charcodeat(i)>255) cur+=1;
//   }
   if(cur==0){ //当默认值长度为0时,可输入数为默认maxlength值,此时不可提交
    count.innerhtml = max;
    submit.disabled=true;
    warn.innerhtml="不区分中英文字符数";
   }else if (cur < max) {//当默认值小于限制数时,可输入数为max-cur
    count.innerhtml = max - cur;
    warn.innerhtml="不区分中英文字符数";
   }else{
    count.innerhtml = 0;//当默认值大于等于限制数时,插入一条提示信息并截取限制数内的值
    warn.innerhtml="不可再输入!";
    this.value=val.substring(0,max);//此处前面的this.value不能用变量val,它们不再是同一个值
   }
  }
 }
}

//基于jquery版本
$(function(){
 var _area=$("textarea#jq");
 var _info=_area.next();
 var _submit=_info.find(":submit");
 var _max=_area.attr("maxlength");
 var _val,_cur,_count,_warn;
 _submit.attr("disabled",true);
 _area.bind("keyup change",function(){ //绑定keyup和change事件
  _submit.attr("disabled",false);
  if(_info.find("span").size()<1){//避免每次弹起都会插入一条提示信息
   _info.append("你还可以输入"+ _max +"个字符[不区分中英文字符数]");
  }
  _val=$(this).val();
  _cur=_val.length;
  _count=_info.find("em");
  _warn=_info.find("font");
  
  if(_cur==0){//当默认值长度为0时,可输入数为默认maxlength值,此时不可提交
   _count.text(_max);
   _submit.attr("disabled",true);
  }else if(_cur<_max){//当默认值小于限制数时,可输入数为max-cur
   _count.text(_max-_cur);
   _warn.text("不区分中英文字符数");
  }else{//当默认值大于等于限制数时,插入一条提示信息并截取限制数内的值
   _count.text(0);
   _warn.text("不可再输入!");
   $(this).val(_val.substring(0,_max));
  }
 });
});
</script>





mr.think的博客可自由转载及使用,但请注明出处.

 


//原生javascript版本
window.onload=function(){
 var js=document.getelementbyid("js");//获取文本域
 var info=document.getelementsbytagname("p")[0];//获取要插入提示信息的元素
 var submit=info.getelementsbytagname("input")[0];//获取提交按钮
 var max=js.getattribute("maxlength");//获取限制输入的最大长度
 var tips=document.createelement("span");//新建一个提示span
 var val,cur,count,warn;
 submit.disabled=true;//默认不可提交
 tips.innerhtml="你还可以输入"+max+"个字符[不区分中英文字符数]";
 if(max){
  js.onkeyup=js.onchange=function(){
   submit.disabled=false;
   if(info.lastchild.nodename!="span") info.appendchild(tips);//避免每次弹起都会插入一条提示信息
   count=info.getelementsbytagname("em")[0];//根据输入数字变换区
   warn=info.getelementsbytagname("font")[0];//副标题
   val=this.value;
   cur=val.length;
//   for(var i=0;i255) cur+=1;
//   }
   if(cur==0){ //当默认值长度为0时,可输入数为默认maxlength值,此时不可提交
    count.innerhtml = max;
    submit.disabled=true;
    warn.innerhtml="不区分中英文字符数";
   }else if (cur < max) {//当默认值小于限制数时,可输入数为max-cur
    count.innerhtml = max - cur;
    warn.innerhtml="不区分中英文字符数";
   }else{
    count.innerhtml = 0;//当默认值大于等于限制数时,插入一条提示信息并截取限制数内的值
    warn.innerhtml="不可再输入!";
    this.value=val.substring(0,max);//此处前面的this.value不能用变量val,它们不再是同一个值
   }
  }
 }
}
//基于jquery版本
$(function(){
 var _area=$("textarea#jq");
 var _info=_area.next();
 var _submit=_info.find(":submit");
 var _max=_area.attr("maxlength");
 var _val,_cur,_count,_warn;
 _submit.attr("disabled",true);
 _area.bind("keyup change",function(){ //绑定keyup和change事件
  _submit.attr("disabled",false);
  if(_info.find("span").size()<1){//避免每次弹起都会插入一条提示信息
   _info.append("你还可以输入"+ _max +"个字符[不区分中英文字符数]");
  }
  _val=$(this).val();
  _cur=_val.length;
  _count=_info.find("em");
  _warn=_info.find("font");

  if(_cur==0){//当默认值长度为0时,可输入数为默认maxlength值,此时不可提交
   _count.text(_max);
   _submit.attr("disabled",true);
  }else if(_cur<_max){//当默认值小于限制数时,可输入数为max-cur
   _count.text(_max-_cur);
   _warn.text("不区分中英文字符数");
  }else{//当默认值大于等于限制数时,插入一条提示信息并截取限制数内的值
   _count.text(0);
   _warn.text("不可再输入!");
   $(this).val(_val.substring(0,_max));
  }
 });
});

本文来源:http://www.gdgbn.com/wangyezhizuo/29674/