jQuery计算文本框字数方法

jQuery计算文本框字数方法

$(function(){  



    var $tex = $(".tex");  




    var $but = $(".but");  



    var ie = jQuery.support.htmlSerialize;  



    var str = 0;  




    var abcnum = 0;  




    var maxNum = 280;  




    var texts= 0;  




    var num = 0;  




    var sets = null;      




    $tex.val("");      




    //顶部的提示文字  



    $tex.focus(function(){  



        if($tex.val()==""){  




            $("p").html("您还可以输入的字数<span>140</span>");  



        }      


    })  


    $tex.blur(function(){  



        if($tex.val() == ""){  




            $("p").html("请在下面输入您的文字:");  



        }      


    })      



    //文本框字数计算和提示改变  




    if(ie){  




        $tex[0].oninput = changeNum;  




    }else{  




        $tex[0].onpropertychange  = changeNum;  



    }      


    function changeNum(){  



        //汉字的个数  




        str = ($tex.val().replace(/\w/g,"")).length;  




        //非汉字的个数  



        abcnum = $tex.val().length-str;          



        total = str*2+abcnum;          




        if(str*2+abcnum<maxNum || str*2+abcnum == maxNum){  



                $but.removeClass()  



                $but.addClass("but");  




                texts =Math.ceil((maxNum - (str*2+abcnum))/2);  




                $("p").html("您还可以输入的字数<span>"+texts+"</span>").children().css({"color":"blue"});  




        }else if(str*2+abcnum>maxNum){  




                $but.removeClass("")  




                $but.addClass("grey");  




                texts =Math.ceil(((str*2+abcnum)-maxNum)/2);  




                $("p").html("您输入的字数超过了<span>"+texts+"</span>").children("span").css({"color":"red"});  



        }      


    }      



    //按钮点击  



    $but.click(function(){  



        if($(this).is(".grey")){  




            sets = setInterval(flash,100);  




            $tex.addClass("textColor")  



        }            


        function flash(){              


            num++;  



            if(num == 4){  



                clearInterval(sets);  


            }  



            if(num%2 == 1){  




                $tex.addClass("textColor")  




            }else{  




                $tex.removeClass("textColor")      



            }      


        }  


    })      


}) 

一、功能:

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

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

二、功能分析

重点是用什么事件?

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

字数的计算。

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

闪动背景色

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

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

DEMO下载

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

相关推荐