您的位置:首页 > Web前端 > JavaScript

js实现限制textarea字符输入数量的代码实例

2011-04-09 13:23 483 查看
1. 通过本文demo演示,可以很明显的看到原生js的window.onload=function(){…}与jquery 的$(document).ready(function(){…});的区别,这也是我为什么不用样式定义初始状态下隐藏第二三个显示区的原因;
2. 本文只是选项卡一个原型实现,若要用于同一页面多个选项卡,变量已集中到函数头部,可自行封装成函数;
3. 请不要问如何实现更酷很炫的效果,请自已思考添加效果;
4. 不希望大家用这个效果时只是机械的复制粘贴,思考加实践,然后消化成自己的

<script src="http://ajax.googleapis.com/ajax/libs/jquery/1.4/jquery.min.js"></script>
<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 blog http://www.3ppt.com/
* @2011.04.07
* @可自由转载及使用,但请注明版权归属
*******************************/
//原生网页特效版本
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];//www.3ppt.com根据输入数字变换区
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时,www.3ppt.com可输入数为默认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>

<div id="demo">
<fieldset>
<legend>原生javascript版本</legend>
<form name="jsform" action="#" method="get">
<textarea name="js" id="js" maxlength="10"></textarea>
<p><input type="submit" value="提 交" /></p>
</form>
</fieldset>
<p style="color:#fff">» 我是用来隔行的,别理我^-^</p>
<!--//原生javascript版本-->
<fieldset>
<legend>基于jquery版本</legend>
<form name="jqform" action="#" method="get">
<textarea name="jq" id="jq" maxlength="10"></textarea>
<p><input type="submit" value="提 交" /></p>
</form>
</fieldset>
<!--//基于jquery版本-->
</div>
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: