jQuery计算文本框字数方法

 
 
 
 
  1. $(function(){  
  2.     var $tex = $(".tex");  
  3.     var $but = $(".but");  
  4.     var ie = jQuery.support.htmlSerialize;  
  5.     var str = 0;  
  6.     var abcnum = 0;  
  7.     var maxNum = 280;  
  8.     var texts= 0;  
  9.     var num = 0;  
  10.     var sets = null;      
  11.     $tex.val("");      
  12.     //顶部的提示文字  
  13.     $tex.focus(function(){  
  14.         if($tex.val()==""){  
  15.             $("p").html("您还可以输入的字数140");  
  16.         }      
  17.     })  
  18.     $tex.blur(function(){  
  19.         if($tex.val() == ""){  
  20.             $("p").html("请在下面输入您的文字:");  
  21.         }      
  22.     })      
  23.     //文本框字数计算和提示改变  
  24.     if(ie){  
  25.         $tex[0].oninput = changeNum;  
  26.     }else{  
  27.         $tex[0].onpropertychange  = changeNum;  
  28.     }      
  29.     function changeNum(){  
  30.         //汉字的个数  
  31.         str = ($tex.val().replace(/\w/g,"")).length;  
  32.         //非汉字的个数  
  33.         abcnum = $tex.val().length-str;          
  34.         total = str*2+abcnum;          
  35.         if(str*2+abcnum
  36.                 $but.removeClass()  
  37.                 $but.addClass("but");  
  38.                 texts =Math.ceil((maxNum - (str*2+abcnum))/2);  
  39.                 $("p").html("您还可以输入的字数"+texts+"").children().css({"color":"blue"});  
  40.         }else if(str*2+abcnum>maxNum){  
  41.                 $but.removeClass("")  
  42.                 $but.addClass("grey");  
  43.                 texts =Math.ceil(((str*2+abcnum)-maxNum)/2);  
  44.                 $("p").html("您输入的字数超过了"+texts+"").children("span").css({"color":"red"});  
  45.         }      
  46.     }      
  47.     //按钮点击  
  48.     $but.click(function(){  
  49.         if($(this).is(".grey")){  
  50.             sets = setInterval(flash,100);  
  51.             $tex.addClass("textColor")  
  52.         }            
  53.         function flash(){              
  54.             num++;  
  55.             if(num == 4){  
  56.                 clearInterval(sets);  
  57.             }  
  58.             if(num%2 == 1){  
  59.                 $tex.addClass("textColor")  
  60.             }else{  
  61.                 $tex.removeClass("textColor")      
  62.             }      
  63.         }  
  64.     })      
  65. }) 

一、功能:

为宕昌等地区用户提供了全套网页设计制作服务,及宕昌网站建设行业解决方案。主营业务为成都网站设计、网站建设、宕昌网站设计,以传统方式定制建设网站,并提供域名空间备案等一条龙服务,秉承以专业、用心的态度为用户提供真诚的服务。我们深信只要达到每一位用户的要求,就会得到认可,从而选择与我们长期合作。这样,我们也可以走得更远!

用户边输入计算同时进行,告诉用户还剩余多少可输入的字数;

当超过规定的字数后,点击确定,会让输入框闪动

二、功能分析

重点是用什么事件?

标准浏览器用oninput,而IE则使用onpropertychange ,这两个事件的发生条件,是文本框的值发生改变。

字数的计算。

一个中文算两个,一个符号或数字,英文,算一个。(如果是规定140个字,乘以2,那么就是280个)。需要用到Math.ceil方法,因为***还是要除以2来还原显示给用户的字数;

闪动背景色

这里用到了模运算,因为是重复的动作,***次有颜色,第二次没有颜色,这样重复的动作,就有闪动效果.

因为肉眼要看到这二次有颜色和无颜色的效果,所以需要用到延时,setTimeout和setInterval. 这里用到的是setInterval,因为要重复动作。

DEMO下载

原文链接:http://www.cnblogs.com/lufy/archive/2012/06/05/2537016.html

名称栏目:jQuery计算文本框字数方法
文章URL:http://www.csdahua.cn/qtweb/news49/506599.html

网站建设、网络推广公司-快上网,是专注品牌与效果的网站制作,网络营销seo公司;服务项目有等

广告

声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 快上网