亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

javascript 判斷中文字符長度的函數(shù)代碼

 更新時間:2012年08月27日 14:35:46   作者:  
在很多時候,我們在進行數(shù)據(jù)提交數(shù)據(jù)庫時.先會用javascript對其進行有效性驗證.如一個中文javascript為的length是1.但是數(shù)據(jù)庫中會占二個字節(jié).容易出錯
JS的字符串都是string對象,可以用string對象的length屬性可以獲取其長度,但是無論是中文、全角符號以及英文最小長度單位都是1,這與php的strlen()并不相同。

復(fù)制代碼 代碼如下:

function strlen(str) {
var s = 0;
for(var i = 0; i < str.length; i++) {
if(str.charAt(i).match(/[u0391-uFFE5]/)) {
s += 2;
} else {
s++;
}
}
return s;
}

抓取出每個字符,匹配全角字符和漢字的,則計2個字符,其他的則計1個字符。
復(fù)制代碼 代碼如下:

<script>
alert (fucCheckLength("中國a"));
function fucCheckLength(strTemp)
{
var i,sum;
sum=0;
for(i=0;i<strTemp.length;i++)
{
if ((strTemp.charCodeAt(i)>=0) && (strTemp.charCodeAt(i)<=255))
sum=sum+1;
else
sum=sum+2;
}
return sum;
}
</script>

會得到結(jié)果是:5 要得到的字節(jié)長度吧?請注意字節(jié)和字符的差異。而字節(jié)長度是和編碼有關(guān)系的,比如"中國a",gbk/gb2312編碼是5個字節(jié),可是如果是utf-8,則是7個字節(jié)(utf-8下通常一個漢字3個字節(jié))。
我們可以把所有字符轉(zhuǎn)換在gbk再操作,實例
復(fù)制代碼 代碼如下:

function Utf8ToUnicode(strUtf8)
{
var bstr = "";
var nTotalChars = strUtf8.length; // total chars to be processed.
var nOffset = 0; // processing point on strUtf8
var nRemainingBytes = nTotalChars; // how many bytes left to be converted
var nOutputPosition = 0;
var iCode, iCode1, iCode2; // the value of the unicode.
while (nOffset < nTotalChars)
{
iCode = strUtf8.charCodeAt(nOffset);
if ((iCode & 0x80) == 0) // 1 byte.
{
if ( nRemainingBytes < 1 ) // not enough data
break;
bstr += String.fromCharCode(iCode & 0x7F);
nOffset ++;
nRemainingBytes -= 1;
}
else if ((iCode & 0xE0) == 0xC0) // 2 bytes
{
iCode1 = strUtf8.charCodeAt(nOffset + 1);
if ( nRemainingBytes < 2 || // not enough data
(iCode1 & 0xC0) != 0x80 ) // invalid pattern
{
break;
}
bstr += String.fromCharCode(((iCode & 0x3F) << 6) | ( iCode1 & 0x3F));
nOffset += 2;
nRemainingBytes -= 2;
}
else if ((iCode & 0xF0) == 0xE0) // 3 bytes
{
iCode1 = strUtf8.charCodeAt(nOffset + 1);
iCode2 = strUtf8.charCodeAt(nOffset + 2);
if ( nRemainingBytes < 3 || // not enough data
(iCode1 & 0xC0) != 0x80 || // invalid pattern
(iCode2 & 0xC0) != 0x80 )
{
break;
}
bstr += String.fromCharCode(((iCode & 0x0F) << 12) |
((iCode1 & 0x3F) << 6) |
(iCode2 & 0x3F));
nOffset += 3;
nRemainingBytes -= 3;
}
else // 4 or more bytes -- unsupported
break;
}
if (nRemainingBytes != 0)
{
// bad UTF8 string.
return "";
}
return bstr;
}




如何解決這個問題.本文介紹使用js來獲取中文字長度方法

首先,我們定義一個新的函數(shù)getBytes()取得字符串的字節(jié)數(shù),在javascript里,這個函數(shù)是標準函數(shù)。
復(fù)制代碼 代碼如下:

  String.prototype.getBytes = function() {
  var cArr = this.match(/[^x00-xff]/ig);
  return this.length + (cArr == null ? 0 : cArr.length);
  }
  function paramCheck(cur){
  if(cur.value.getBytes() > 64){
  alert("字符超過64個字符");
  return false;
  }
  return true;
  }

  getBytes用正則表達式來判斷字符串中包含漢字的個數(shù),包含的漢字都放到數(shù)組cArr中,這樣cArr的長度就是漢字的總數(shù)。getBytes方法返回length加上漢字數(shù),就是總的字節(jié)數(shù)。
  只是使用了[^x00-xff],這個有點惡心,有些特殊字符也是能匹配到的,比如}等。
  但是如果使用[^u4E00-u9FA5]的話,卻不能匹配到中文……

以下是另外幾種方法,大家可以測試下:
一種:
復(fù)制代碼 代碼如下:

function _length(str){
var len=0;
for(var i=0;i<str.length;i++){
if(str.charAt(i)>'~'){len+=2;}else{len++;}
}
return len;
}

二種:
復(fù)制代碼 代碼如下:

String.prototype.gblen = function() {
var len = 0;
for (var i=0; i<this.length; i++) {
if (this.charCodeAt(i)>127 || this.charCodeAt(i)==94) {
len += 2;
} else {
len ++;
}
}
return len;
}
String.prototype.gbtrim = function(len, s) {
var str = '';
var sp = s || '';
var len2 = 0;
for (var i=0; i<this.length; i++) {
if (this.charCodeAt(i)>127 || this.charCodeAt(i)==94) {
len2 += 2;
} else {
len2 ++;
}
}
if (len2 <= len) {
return this;
}
len2 = 0;
len = (len > sp.length) ? len-sp.length: len;
for (var i=0; i<this.length; i++) {
if (this.charCodeAt(i)>127 || this.charCodeAt(i)==94) {
len2 += 2;
} else {
len2 ++;
}
if (len2 > len) {
str += sp;
break;
}
str += this.charAt(i);
}
return str;
}
var str1 = '世上最牛的@#%&們 世上最牛的@#%&們';
document.write('str1 = '+ str1 +'
');
document.write('length = '+ str1.gblen() +'
');
document.write('gbtrim(10) = '+ str1.gbtrim(10) +'
');
document.write('gbtrim(10, \'…\') = '+ str1.gbtrim(10, '…') +'
');
document.write('gbtrim(12, \'-\' ) = '+ str1.gbtrim(12, '-') +'
');

// gbtrim(len 截取長度,按英文字節(jié)長度計算, s截取后的省略字符,如"…" )
// 備注: 這里中文字符都是當作兩個長度來計算的,所以gbtrim中的len為10時,是顯示最多5個漢字的。
// 當漢字數(shù)大于5時,由于截取后加上“…”,所以只顯示4個漢字。

相關(guān)文章

  • 原生Javascript實現(xiàn)五角星評分

    原生Javascript實現(xiàn)五角星評分

    這篇文章主要為大家詳細介紹了原生Javascript實現(xiàn)五角星評分,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2022-09-09
  • javascript之學(xué)會吝嗇 精簡代碼

    javascript之學(xué)會吝嗇 精簡代碼

    前端開發(fā),要學(xué)會吝嗇:
    2010-04-04
  • 利用JavaScript實現(xiàn)防抖節(jié)流函數(shù)的示例代碼

    利用JavaScript實現(xiàn)防抖節(jié)流函數(shù)的示例代碼

    在開發(fā)中我們經(jīng)常會遇到一些高頻操作,比如:鼠標移動,滑動窗口,鍵盤輸入等等,節(jié)流和防抖就是對此類事件進行優(yōu)化,降低觸發(fā)的頻率,以達到提高性能的目的。本文就教大家如何實現(xiàn)一個讓面試官拍大腿的防抖節(jié)流函數(shù),需要的可以參考一下
    2022-08-08
  • 用javascript實現(xiàn)讀取txt文檔的腳本

    用javascript實現(xiàn)讀取txt文檔的腳本

    用javascript實現(xiàn)讀取txt文檔的腳本...
    2007-07-07
  • js原生方法被覆蓋,從新賦值原生的方法

    js原生方法被覆蓋,從新賦值原生的方法

    下面小編就為大家分享一篇js原生方法被覆蓋,從新賦值原生的方法,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧
    2018-01-01
  • JavaScript獲得頁面base標簽中url的方法

    JavaScript獲得頁面base標簽中url的方法

    這篇文章主要介紹了JavaScript獲得頁面base標簽中url的方法,涉及javascript中元素的獲取及href屬性的使用技巧,需要的朋友可以參考下
    2015-04-04
  • 分析uniapp入門之nvue爬坑記

    分析uniapp入門之nvue爬坑記

    uni-app的nvue說白了就是weex的那一套東西,uni-app集成了weex的 SDK,也就實現(xiàn)了App端的原生渲染能力。本文將介紹uniapp遇到的一些坑,分享給大家。
    2021-06-06
  • JS中${}什么意思有什么作用

    JS中${}什么意思有什么作用

    在JavaScript中,${}用于模板文字(template?literals),為ES6中新增的字符串方法,其作用是配合反單引號實現(xiàn)字符串拼,代替以前傳統(tǒng)復(fù)雜的引號雙引號與+的拼接,簡介明了,非常好用,本文給大家介紹JS中‘${}‘什么意思有什么作用,感興趣的朋友一起看看吧
    2023-08-08
  • JavaScript十大取整方法實例教程

    JavaScript十大取整方法實例教程

    這篇文章主要給大家介紹了關(guān)于JavaScript的十大取整方法,文中通過示例代碼介紹的非常詳細,對大家的學(xué)習或者工作具有一定的參考學(xué)習價值,需要的朋友們下面隨著小編來一起學(xué)習學(xué)習吧
    2020-12-12

最新評論