區(qū)分中英文字符的兩種方法(正則和charCodeAt())
更新時間:2010年11月05日 18:31:25 作者:
最近在為項目寫登錄注冊系列頁面, 表單驗證無疑是不可缺少的部分, 在這個jQ插件滿天飛的web年代, 表單驗證倒也不是難事. 但再好的插件, 也并不能做到十全十美
比如這次用到的我先前介紹過的Vanadium表單驗證插件, 因為是E文中不存在占2個字符的字, 所以, 區(qū)分中英文字符就得自己擴展. 本文就將介紹兩種區(qū)分中英文字符的方法: 利用正則和charCodeAt方法區(qū)分中英文字符.
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
正則無疑是最強大的判斷各種條件的方法, 最近也在研習它, 雖然枯燥, 但仍有樂趣. 用它來判斷一個雙字節(jié)的中文字符也是輕而易舉地. 而判斷中文字符, Mr.Think也是非常推薦用這種方法的, 簡單且執(zhí)行效率高.
核心代碼如下:
regExpForm.onblur=function(){
entryVal=this.value;
entryLen=entryVal.length;
cnChar=entryVal.match(/[^\x00-\x80]/g);//利用match方法檢索出中文字符并返回一個存放中文的數(shù)組
entryLen+=cnChar.length;//算出實際的字符長度
}
第二種方法是通過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ù)組的末尾添加一個或多個元素并返回新的長度,所以未刷新的情況下反復blur會累加字符值
}
}
entryLen+=cnArr.length;
[Ctrl+A 全選 注:引入外部Js需再刷新一下頁面才能執(zhí)行]
正則無疑是最強大的判斷各種條件的方法, 最近也在研習它, 雖然枯燥, 但仍有樂趣. 用它來判斷一個雙字節(jié)的中文字符也是輕而易舉地. 而判斷中文字符, Mr.Think也是非常推薦用這種方法的, 簡單且執(zhí)行效率高.
核心代碼如下:
復制代碼 代碼如下:
regExpForm.onblur=function(){
entryVal=this.value;
entryLen=entryVal.length;
cnChar=entryVal.match(/[^\x00-\x80]/g);//利用match方法檢索出中文字符并返回一個存放中文的數(shù)組
entryLen+=cnChar.length;//算出實際的字符長度
}
第二種方法是通過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ù)組的末尾添加一個或多個元素并返回新的長度,所以未刷新的情況下反復blur會累加字符值
}
}
entryLen+=cnArr.length;
相關文章
js傳各種類型參數(shù)到Controller層的整理方式
這篇文章主要介紹了js傳各種類型參數(shù)到Controller層的整理方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2023-02-02JavaScript數(shù)組隨機排列實現(xiàn)隨機洗牌功能
這篇文章主要介紹了JavaScript數(shù)組隨機排列實現(xiàn)隨機洗牌功能的方法,涉及javascript中基于list.sort方法實現(xiàn)數(shù)組隨機排列的技巧,可應用于隨機洗牌,非常具有實用價值,需要的朋友可以參考下2015-03-03使用wxapp-img-loader自定義組件實現(xiàn)微信小程序圖片預加載功能
由于微信小程序沒有提供類似 Image 這樣的 JS 對象,要實現(xiàn)圖片的預加載要麻煩一些,wxapp-img-loader自定義組件可以在微信小程序中實現(xiàn)圖片預加載功能,需要的朋友可以參考下2018-10-10