jqyery与javascript 限制字符输入数功能

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));
  }
 });
});

时间: 2024-10-29 20:25:20

jqyery与javascript 限制字符输入数功能的相关文章

限制字符输入数功能(jquery版和原生JS版)_jquery

Mr.Think的个人博客 @专注前端技术,热爱PHP,崇尚简单生活. 返回文章页:限制字符输入数功能(jQ版和原生JS版)@Mr.Think 原生JavaScript版本 » 我是用来隔行的,别理我^-^ 基于jQuery版本

用JavaScript实现页面重定向功能的教程

  这篇文章主要介绍了用JavaScript实现页面重定向功能的教程,是JS入门学习中的基础知识,需要的朋友可以参考下 页面重定向是什么? 当你点击一个URL来访问一个网页X,但在内部你被定向到另一页Y,仅仅是因为页面重定向.这一概念是从不同于JavaScript 页面刷新 . 可能有各种原因,为什么想从原来的页面重定向.下面列出的几个原因: 如果不喜欢你的域名,可以重定向到一个新的.同时,要引导所有访问者到新网站.在这种情况下,可以保持旧的域名,但放在一个页面到一个页面重定向使所有的旧域名游客

深入剖析JavaScript中的枚举功能

 本篇文章主要是对JavaScript中的枚举功能进行了详细的介绍,需要的朋友可以过来参考下,希望对大家有所帮助 由于 Microsoft AJAX Library 对于 JavaScript 进行了大幅扩展,   枚举这个常用的功能当然也被加进去了,   本次就是来探讨 JavaScript 的枚举功能.   由于范例很简单,   所以直接看 HTML 标签就 OK 了    代码如下: <html xmlns="http://www.w3.org/1999/xhtml">

用JavaScript实现类似于ListBox功能示例代码

 这篇文章主要介绍了用JavaScript实现类似于ListBox功能,需要的朋友可以参考下 JavaScript对于多项数据的请求和处理过程中,如何实现常常困扰很多程序员,如何进行动态编辑和删除而不影响其他的数据项,今天介绍一种方法,可供借鉴,例如通过XmlRequest请求到如下数据:  代码如下: <span style="font-size:14px;">{ "Table":  [  { "Id": 3, "Type

JavaScript中的ajax功能的概念和示例详解_javascript技巧

AJAX即"Asynchronous Javascript And XML"(异步JavaScript和XML). 个人理解:ajax就是无刷新提交,然后得到返回内容. 对应的不使用ajax时的传统网页如果需要更新内容(或用php做处理时),必须重载整个网页页面. 示例: html代码如下 <!DOCTYPE html> <html> <head> <meta charset="UTF-8"> <title>

使用javascript实现的一些功能

原文:使用javascript实现的一些功能                  今天学习了javascript中的事件,已经接近尾声,可以说明天跨入jquery的学习啦,学习了一周的javascript,感觉还没有掌握其中学习的微妙之处,javascript使用起来是比较灵活的,而且很多浏览器的兼容性还是不一样的,嘿嘿,或许这就是原因的所在吧,在事件的处理上面还是很容易理解的,前面学习了那么多的语法知识以及对DOM的操作,想必在事件的学习上还是很容易接受的,就来总结一下吧.          一

菜鸟蔡之Ajax复习第一篇(后台asp.net)(传统的JavaScript方法实现Ajax功能)_AJAX相关

其实最简单的可以理解为:JavaScript + XMLHttpRequest + CSS +服务器端的集合,其本质上是一种浏览器端的技术.好了, 简单的描述了一下,现在直接上代码吧! (1).功能描述: 新建两个html页面分别为1.html和2.html,在不刷新的情况下点击1.html页面上的"获取数据"按钮后,将2.html页中的内容显示在1.html页面的<div>标记中. (2).实现代码: 1.html实现代码: 复制代码 代码如下: <head>

常用Javascript函数与原型功能收藏(必看篇)_javascript技巧

如下所示: // 重复字符串 String.prototype.repeat = function(n) { return new Array(n+1).join(this); } // 替换全部 String.prototype.replaceAll = function(str1, str2) { return this.replace(new RegExp(str1, "gm"), str2); } // 清除空格 String.prototype.trim = function

JavaScript蒙板(model)功能的简单实现代码_javascript技巧

思路: •创建一个蒙板, 设置蒙板的堆叠顺序保证能将其它元素盖住 position: absolute; top: 0; left: 0; display: none; background-color: rgba(9, 9, 9, 0.63); width: 100%; height: 100%; z-index: 1000; •设置蒙板中内容的背景色和展示格式 width: 50%; text-align: center; background: #ffffff; border-radius