日本综合一区二区|亚洲中文天堂综合|日韩欧美自拍一区|男女精品天堂一区|欧美自拍第6页亚洲成人精品一区|亚洲黄色天堂一区二区成人|超碰91偷拍第一页|日韩av夜夜嗨中文字幕|久久蜜综合视频官网|精美人妻一区二区三区

RELATEED CONSULTING
相關(guān)咨詢
選擇下列產(chǎn)品馬上在線溝通
服務(wù)時(shí)間:8:30-17:00
你可能遇到了下面的問題
關(guān)閉右側(cè)工具欄

新聞中心

這里有您想知道的互聯(lián)網(wǎng)營銷解決方案
jQuery計(jì)算文本框字?jǐn)?shù)方法

 
 
 
 
  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("您還可以輸入的字?jǐn)?shù)140");  
  16.         }      
  17.     })  
  18.     $tex.blur(function(){  
  19.         if($tex.val() == ""){  
  20.             $("p").html("請?jiān)谙旅孑斎肽奈淖郑?);  
  21.         }      
  22.     })      
  23.     //文本框字?jǐn)?shù)計(jì)算和提示改變  
  24.     if(ie){  
  25.         $tex[0].oninput = changeNum;  
  26.     }else{  
  27.         $tex[0].onpropertychange  = changeNum;  
  28.     }      
  29.     function changeNum(){  
  30.         //漢字的個(gè)數(shù)  
  31.         str = ($tex.val().replace(/\w/g,"")).length;  
  32.         //非漢字的個(gè)數(shù)  
  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("您還可以輸入的字?jǐn)?shù)"+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("您輸入的字?jǐn)?shù)超過了"+texts+"").children("span").css({"color":"red"});  
  45.         }      
  46.     }      
  47.     //按鈕點(diǎn)擊  
  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. }) 

一、功能:

為宕昌等地區(qū)用戶提供了全套網(wǎng)頁設(shè)計(jì)制作服務(wù),及宕昌網(wǎng)站建設(shè)行業(yè)解決方案。主營業(yè)務(wù)為成都網(wǎng)站設(shè)計(jì)、網(wǎng)站建設(shè)、宕昌網(wǎng)站設(shè)計(jì),以傳統(tǒng)方式定制建設(shè)網(wǎng)站,并提供域名空間備案等一條龍服務(wù),秉承以專業(yè)、用心的態(tài)度為用戶提供真誠的服務(wù)。我們深信只要達(dá)到每一位用戶的要求,就會(huì)得到認(rèn)可,從而選擇與我們長期合作。這樣,我們也可以走得更遠(yuǎn)!

用戶邊輸入計(jì)算同時(shí)進(jìn)行,告訴用戶還剩余多少可輸入的字?jǐn)?shù);

當(dāng)超過規(guī)定的字?jǐn)?shù)后,點(diǎn)擊確定,會(huì)讓輸入框閃動(dòng)

二、功能分析

重點(diǎn)是用什么事件?

標(biāo)準(zhǔn)瀏覽器用oninput,而IE則使用onpropertychange ,這兩個(gè)事件的發(fā)生條件,是文本框的值發(fā)生改變。

字?jǐn)?shù)的計(jì)算。

一個(gè)中文算兩個(gè),一個(gè)符號(hào)或數(shù)字,英文,算一個(gè)。(如果是規(guī)定140個(gè)字,乘以2,那么就是280個(gè))。需要用到Math.ceil方法,因?yàn)?**還是要除以2來還原顯示給用戶的字?jǐn)?shù);

閃動(dòng)背景色

這里用到了模運(yùn)算,因?yàn)槭侵貜?fù)的動(dòng)作,***次有顏色,第二次沒有顏色,這樣重復(fù)的動(dòng)作,就有閃動(dòng)效果.

因?yàn)槿庋垡吹竭@二次有顏色和無顏色的效果,所以需要用到延時(shí),setTimeout和setInterval. 這里用到的是setInterval,因?yàn)橐貜?fù)動(dòng)作。

DEMO下載

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


分享名稱:jQuery計(jì)算文本框字?jǐn)?shù)方法
當(dāng)前地址:http://www.dlmjj.cn/article/coccdch.html