posts - 6,comments - 7,trackbacks - 0

          常用鏈接

          留言簿(1)

          隨筆分類

          文章分類

          相冊

          收藏夾

          blog社區(qū)

          下載區(qū)-點擊連接直接下載

          技術(shù)類連接

          非技術(shù)類連接

          積分與排名

          • 積分 - 6647
          • 排名 - 2802

          最新評論

          閱讀排行榜

          評論排行榜

          ????
          ??? 做項目時自己寫一段js給大家。關(guān)于文本限制字?jǐn)?shù)的問題,在實際開發(fā)中經(jīng)常用到;主要問題出現(xiàn)在對中文的限制,因為大多數(shù)據(jù)庫都是按字節(jié)限制,而web中屬性maxlength限制個數(shù),非字節(jié)數(shù),因此遇到中文就會出問題。下面代碼就解決關(guān)于限制字節(jié)數(shù)的校驗問題;只要將此下代碼保存到一個js文件中并引入到校驗的頁面中,便可使用!同時希望大家給與大力支持和寶貴意見,本人會在今后閑余之際,發(fā)表更多的好文章,謝謝!!

          ?

          /*
          ?value:?值;
          ?byteLength:數(shù)據(jù)庫字節(jié)長度
          ?title:字段中文名稱
          ?attribute:屬性名稱
          ?使用方法說明:

          添加?(1)?onkeyup="limitLength(this.value,100,'名稱','name')"
          ??????????(2)??id="name"?或【struts標(biāo)簽】styleId="name"
          ?注意:id名稱和?attribute屬性名稱要一樣
          ?????
          ?例子:<textarea??name="explain"?id="explain"?onkeyup="limitLength(value,5,'語義說明','explain')"?>?

          ?或

          <input?type="text"???name="explain"??id="explain"?onkeyup="limitLength(value,5,'語義說明','explain')"?>

          */



          function ?limitLength(value,?byteLength,?title,?attribute)?{
          ???????
          var ?newvalue? = ?value.replace( / [ ^ \x00 - \xff] / g,? " ** " );
          ???????
          var ?length? = ?newvalue.length;
          ?
          ???????
          // 當(dāng)填寫的字節(jié)數(shù)小于設(shè)置的字節(jié)數(shù)
          ?????? if ?(length? * ? 1 ? <= byteLength? * ? 1 ){
          ????????????
          return ;
          ??????}
          ??????
          var ?limitDate? = ?newvalue.substr( 0 ,?byteLength);
          ??????
          var ?count? = ? 0 ;
          ??????
          var ?limitvalue? = ? "" ;
          ?????
          for ?( var ?i? = ? 0 ;?i? < ?limitDate.length;?i ++ )?{
          ?????????????
          var ?flat? = ?limitDate.substr(i,? 1 );
          ????????????
          if ?(flat? == ? " * " )?{
          ??????????????????count
          ++ ;
          ????????????}
          ?????}
          ?????
          var ?size? = ? 0 ;
          ?????
          var ?istar? = ?newvalue.substr(byteLength? * ? 1 ? - ? 1 ,? 1 ); // 校驗點是否為“×”
          ??
          ????
          // if?基點是×;?判斷在基點內(nèi)有×為偶數(shù)還是奇數(shù)?
          ????? if ?(count? % ? 2 ? == ? 0 )?{
          ??????????????
          // 當(dāng)為偶數(shù)時
          ????????????size? = ?count? / ? 2 ? + ?(byteLength? * ? 1 ? - ?count);
          ????????????limitvalue?
          = ?value.substr( 0 ,?size);
          ????}?
          else ?{
          ????????????
          // 當(dāng)為奇數(shù)時
          ????????????size? = ?(count? - ? 1 )? / ? 2 ? + ?(byteLength? * ? 1 ? - ?count);
          ????????????limitvalue?
          = ?value.substr( 0 ,?size);
          ????}
          ???alert(title?
          + ? " 最大輸入 " ? + ?byteLength? + ? " 個字節(jié)(相當(dāng)于 " + byteLength? / 2 + " 個漢字)! " );
          ???document.getElementById(attribute).value?
          = ?limitvalue;
          ???
          return ;
          }

          posted on 2006-09-11 12:53 扁豆 閱讀(528) 評論(2)  編輯  收藏

          FeedBack:
          # re: 經(jīng)典限制文本字節(jié)數(shù)javaScript代碼!
          2006-09-28 19:14 | 流氓
          不錯,此方法比較好用!  回復(fù)  更多評論
            
          # re: 經(jīng)典限制文本字節(jié)數(shù)javaScript代碼!
          2006-12-01 11:16 | allen[匿名]
          已經(jīng)用在項目中啦!多謝  回復(fù)  更多評論
            

          只有注冊用戶登錄后才能發(fā)表評論。


          網(wǎng)站導(dǎo)航:
           
          主站蜘蛛池模板: 泸州市| 广南县| 盐源县| 大兴区| 阿克| 玉溪市| 怀化市| 凤台县| 合肥市| 和静县| 临高县| 土默特右旗| 大港区| 阳山县| 保亭| 盘锦市| 天等县| 温宿县| 璧山县| 舟曲县| 称多县| 宝坻区| 绥德县| 晋宁县| 华池县| 汉阴县| 江西省| 扶风县| 宁乡县| 白城市| 新晃| 江达县| 广丰县| 和静县| 安吉县| 哈密市| 和龙市| 织金县| 德惠市| 上饶县| 金堂县|