jqyery與javascript 限制字元輸入數功能

來源:互聯網
上載者:User

jqyery與網頁特效 限制字元輸入數功能

<style>
/*demo css教程*/
fieldset{border:1px solid #ccc;width:720px}
fieldset legend{ background:#a40000; color:#fff;text-align:center; padding:0 8px; margin-left:25px}
fieldset form{background:#eee; border:1px solid #ccc;margin:10px; padding:10px 10px 0}
fieldset form textarea{width:670px; height:60px; border:1px solid #ccc; line-height:25px; padding:3px;overflow:hidden;}
fieldset form textarea:focus{border:1px solid #a40000}
fieldset form p{height:30px; margin:2px 0;*margin:3px 0 3px -5px}
fieldset form p span{padding-left:8px}
fieldset form p span em{font-style:normal; font-weight:bolder; color:#047; padding:0 3px}
fieldset form p span font{color:blue; font-size:10px}
</style>
<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='你還可以輸入<em>'+max+'</em>個字元<font>[不區分中英文字元數]</font>';
 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<val.length; 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('<span>你還可以輸入<em>'+ _max +'</em>個字元<font>[不區分中英文字元數]</font></span>');
  }
  _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>

<meta http-equiv="content-type" content="text/html; charset=gb2312">
</head>
<body>
<div id="d_head">
<h1><a title="返回mr.think的部落格" href="http://mrthink.net/">mr.think的部落格</a><em>可自由轉載及使用,但請註明出處.</em></h1>

</div> 


//原生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='你還可以輸入<em>'+max+'</em>個字元<font>[不區分中英文字元數]</font>';
 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<val.length; if(val.charcodeat(i) 此迴圈是用來判斷中英文字元的,但並不建議那樣做 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('<span>你還可以輸入<em>'+ _max +'</em>個字元<font>[不區分中英文字元數]</font></span>');
  }
  _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));
  }
 });
});

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.