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

js獲取字符串字節(jié)數(shù)方法小結(jié)

 更新時(shí)間:2015年06月09日 15:20:07   作者:McJeremy&Fan  
這篇文章主要介紹了js獲取字符串字節(jié)數(shù)方法,實(shí)例總結(jié)了javascript字符串長(zhǎng)度計(jì)算的相關(guān)技巧,需要的朋友可以參考下

本文實(shí)例講述了js獲取字符串字節(jié)數(shù)的方法。分享給大家供大家參考。具體如下:

大家都知道,獲取字符串的長(zhǎng)度可用length來(lái)獲取,
那么獲取這段字符串的字節(jié)數(shù)呢?

英文字母肯定lenght和字節(jié)數(shù)都一樣:都是1
而中文lenght=1,字節(jié)數(shù)=2
因此,需要作的就是把中文字符的字節(jié)數(shù)計(jì)算出來(lái)。

方法一:

alert('a'.replace(/[^\u0000-\u00ff]/g,"aaa").length); 
//原理:把中文字符替換成2個(gè)英文字母,那么字節(jié)數(shù)就是2,
//示例中改成替換成3個(gè)英文字母了。
//因此彈出的字節(jié)數(shù)是3,如果要正確的,當(dāng)然是替換成2個(gè)字母了
//\u0000這個(gè)表示的是unicode編碼

方法二:

var str='我我我';
var bytesCount;
for (var i = 0; i < str.length; i++)
{
  var c = str.charAt(i);
  if (/^[\u0000-\u00ff]$/.test(c)) //匹配雙字節(jié)
  {
  bytesCount += 1;
  }
  else
  {
  bytesCount += 2;
  }
}
alert(bytesCount);
//結(jié)果是6
//原理也很簡(jiǎn)單,用正則判斷是不是中文,如果是的話,字節(jié)數(shù)就加1。

匹配中文字符的正則表達(dá)式: [\u4e00-\u9fa5]

匹配雙字節(jié)字符(包括漢字在內(nèi)):[^\x0000-\x00ff]

可以用來(lái)計(jì)算字符串的長(zhǎng)度(一個(gè)雙字節(jié)字符長(zhǎng)度計(jì)2,ASCII字符計(jì)1)

JS中的幾個(gè)函數(shù):

charAt(num) //獲取字符串的num位置的字符
charCodeAt(num)//獲取字符串的num位置的字符的unicode編碼 
fromCharCode(num)//獲取unicode編碼對(duì)應(yīng)的字符

希望本文所述對(duì)大家的javascript程序設(shè)計(jì)有所幫助。

相關(guān)文章

最新評(píng)論