利用JS如何計算字符串所占字節(jié)數(shù)示例代碼
前言
在工作中是不是經常會遇到字符串,但是要求控制字節(jié)數(shù)的需求?因為很多時候數(shù)據(jù)庫中對字節(jié)數(shù)有控制,所以在前端過程中就需要判斷一下,今天我們來分享一下。
本文主要給大家介紹了關于JS計算字符串所占字節(jié)數(shù)的相關內容,分享出來供大家參考學習,下面話不多說了,來一起看看詳細的介紹吧。
示例代碼
/**
* 計算字符串所占的內存字節(jié)數(shù),默認使用UTF-8的編碼方式計算,也可制定為UTF-16
* UTF-8 是一種可變長度的 Unicode 編碼格式,使用一至四個字節(jié)為每個字符編碼
*
* 000000 - 00007F(128個代碼) 0zzzzzzz(00-7F) 一個字節(jié)
* 000080 - 0007FF(1920個代碼) 110yyyyy(C0-DF) 10zzzzzz(80-BF) 兩個字節(jié)
* 000800 - 00D7FF
00E000 - 00FFFF(61440個代碼) 1110xxxx(E0-EF) 10yyyyyy 10zzzzzz 三個字節(jié)
* 010000 - 10FFFF(1048576個代碼) 11110www(F0-F7) 10xxxxxx 10yyyyyy 10zzzzzz 四個字節(jié)
*
* 注: Unicode在范圍 D800-DFFF 中不存在任何字符
* {@link http://zh.wikipedia.org/wiki/UTF-8}
*
* UTF-16 大部分使用兩個字節(jié)編碼,編碼超出 65535 的使用四個字節(jié)
* 000000 - 00FFFF 兩個字節(jié)
* 010000 - 10FFFF 四個字節(jié)
*
* {@link http://zh.wikipedia.org/wiki/UTF-16}
* @param {String} str
* @param {String} charset utf-8, utf-16
* @return {Number}
*/
var sizeof = function(str, charset){
var total = 0,
charCode,
i,
len;
charset = charset ? charset.toLowerCase() : '';
if(charset === 'utf-16' || charset === 'utf16'){
for(i = 0, len = str.length; i < len; i++){
charCode = str.charCodeAt(i);
if(charCode <= 0xffff){
total += 2;
}else{
total += 4;
}
}
}else{
for(i = 0, len = str.length; i < len; i++){
charCode = str.charCodeAt(i);
if(charCode <= 0x007f) {
total += 1;
}else if(charCode <= 0x07ff){
total += 2;
}else if(charCode <= 0xffff){
total += 3;
}else{
total += 4;
}
}
}
return total;
}
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關文章
bootstrap table動態(tài)加載數(shù)據(jù)示例代碼
本篇文章主要介紹了bootstrap table動態(tài)加載數(shù)據(jù)示例代碼,可以實現(xiàn)點擊選擇按鈕,彈出模態(tài)框,加載出關鍵詞列表,有興趣的可以了解一下。2017-03-03
ie6下png圖片背景不透明的解決辦法使用js實現(xiàn)
我們時常在使用png圖片的時候,在ie6下發(fā)生背景不透明的問題,解決的方法實在是太多了,下面給大家介紹下一個js解決的方式,感興趣的朋友可以了解下的2013-01-01
javascript實現(xiàn)循環(huán)廣告條效果
這篇文章主要為大家詳細介紹了javascript實現(xiàn)循環(huán)廣告條效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2017-12-12
echarts實現(xiàn)橫向和縱向滾動條(使用dataZoom)
這篇文章主要給大家介紹了關于echarts使用dataZoom實現(xiàn)橫向和縱向滾動條的相關資料,最近項目中使用到echarts圖表,當數(shù)據(jù)過多時需要添加橫向滾動條,需要的朋友可以參考下2023-08-08

