區(qū)分中英文字符的兩種方法(正則和charCodeAt())
更新時間:2010年11月05日 18:31:25 作者:
最近在為項(xiàng)目寫登錄注冊系列頁面, 表單驗(yàn)證無疑是不可缺少的部分, 在這個jQ插件滿天飛的web年代, 表單驗(yàn)證倒也不是難事. 但再好的插件, 也并不能做到十全十美
比如這次用到的我先前介紹過的Vanadium表單驗(yàn)證插件, 因?yàn)槭荅文中不存在占2個字符的字, 所以, 區(qū)分中英文字符就得自己擴(kuò)展. 本文就將介紹兩種區(qū)分中英文字符的方法: 利用正則和charCodeAt方法區(qū)分中英文字符.
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
正則無疑是最強(qiáng)大的判斷各種條件的方法, 最近也在研習(xí)它, 雖然枯燥, 但仍有樂趣. 用它來判斷一個雙字節(jié)的中文字符也是輕而易舉地. 而判斷中文字符, Mr.Think也是非常推薦用這種方法的, 簡單且執(zhí)行效率高.
核心代碼如下:
regExpForm.onblur=function(){
entryVal=this.value;
entryLen=entryVal.length;
cnChar=entryVal.match(/[^\x00-\x80]/g);//利用match方法檢索出中文字符并返回一個存放中文的數(shù)組
entryLen+=cnChar.length;//算出實(shí)際的字符長度
}
第二種方法是通過charCodeAt()方法判斷Unicode碼值, 若大于255即為中文字符(為什么? 請Google ). Mr.Think并不建議用這種方法的, 它的執(zhí)行效率沒有正則高, 也沒有正則簡單.
核心代碼如下:
entryVal=this.value;
entryLen=entryVal.length;
for(var i=0;i<entryVal.length;i++){
if(entryVal.charCodeAt(i)>255){//遍歷判斷字符串中每個字符的Unicode碼,大于255則為中文
cnArr.push(entryVal[i]);//講符合條件的值插入到中文字符數(shù)組中
//注意一個小bug,push是向數(shù)組的末尾添加一個或多個元素并返回新的長度,所以未刷新的情況下反復(fù)blur會累加字符值
}
}
entryLen+=cnArr.length;
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
正則無疑是最強(qiáng)大的判斷各種條件的方法, 最近也在研習(xí)它, 雖然枯燥, 但仍有樂趣. 用它來判斷一個雙字節(jié)的中文字符也是輕而易舉地. 而判斷中文字符, Mr.Think也是非常推薦用這種方法的, 簡單且執(zhí)行效率高.
核心代碼如下:
復(fù)制代碼 代碼如下:
regExpForm.onblur=function(){
entryVal=this.value;
entryLen=entryVal.length;
cnChar=entryVal.match(/[^\x00-\x80]/g);//利用match方法檢索出中文字符并返回一個存放中文的數(shù)組
entryLen+=cnChar.length;//算出實(shí)際的字符長度
}
第二種方法是通過charCodeAt()方法判斷Unicode碼值, 若大于255即為中文字符(為什么? 請Google ). Mr.Think并不建議用這種方法的, 它的執(zhí)行效率沒有正則高, 也沒有正則簡單.
核心代碼如下:
復(fù)制代碼 代碼如下:
entryVal=this.value;
entryLen=entryVal.length;
for(var i=0;i<entryVal.length;i++){
if(entryVal.charCodeAt(i)>255){//遍歷判斷字符串中每個字符的Unicode碼,大于255則為中文
cnArr.push(entryVal[i]);//講符合條件的值插入到中文字符數(shù)組中
//注意一個小bug,push是向數(shù)組的末尾添加一個或多個元素并返回新的長度,所以未刷新的情況下反復(fù)blur會累加字符值
}
}
entryLen+=cnArr.length;
相關(guān)文章
js實(shí)現(xiàn)圖片旋轉(zhuǎn)的三種方法
這篇文章主要介紹了js實(shí)現(xiàn)圖片旋轉(zhuǎn)的三種方法,需要的朋友可以參考下2014-04-04
Bootstrap 表單驗(yàn)證formValidation 實(shí)現(xiàn)遠(yuǎn)程驗(yàn)證功能
這篇文章主要介紹了Bootstrap 表單驗(yàn)證formValidation 實(shí)現(xiàn)遠(yuǎn)程驗(yàn)證功能,需要的朋友可以參考下2017-05-05
部分網(wǎng)站允許空白referer的防盜鏈圖片的js破解代碼
主要是有些網(wǎng)站的圖片調(diào)用是防盜鏈的但一般只是判斷referer是不是自己網(wǎng)站,如果referer為空也會顯示圖片,所以有了下面的代碼。2011-05-05
使用Object.defineProperty為對象定義屬性
這篇文章主要為大家介紹了使用Object.defineProperty為對象定義屬性示例解析,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-08-08
javascript RadioButtonList獲取選中值
js獲取RadioButtonList值的代碼。2009-04-04

