學習使用JavaScript實作UTF-8編解碼

coldplay.xixi
發布: 2021-02-01 17:31:00
轉載
2887 人瀏覽過

學習使用JavaScript實作UTF-8編解碼

首先简单介绍一下UTF-8。UTF-8以字节为单位对Unicode进行编码。 UTF-8的特点是对不同范围的字符使用不同长度的编码。 对于0x00-0x7F之间的字符,UTF-8编码与ASCII编码完全相同。UTF-8编码的最大长度是6个字节。 6字节模板有31个x,即可以容纳31位二进制数字。Unicode的最大码位0x7FFFFFFF也只有31位。
登入後複製

從Unicode到UTF-8的編碼方式如下:

Unicode編碼(十六進位) UTF-8 位元組流(二進位)
#000000-00007F 0xxxxxxx
#000080-0007FF 110xxxxx 10xxxxxx
00800-00FFFF #1110xxxx 10xxxxxx 10xxxxxx
000000 -10FFFF 11110xxx10xxxxxx10xxxxxx10xxxxxx
##以下是js實作程式碼,首先是編碼

function utf8Encode(inputStr) { var outputStr = ""; for(var i = 0; i < inputStr.length; i++) { var temp = inputStr.charCodeAt(i); //0xxxxxxx if(temp < 128) { outputStr += String.fromCharCode(temp); } //110xxxxx 10xxxxxx else if(temp < 2048) { outputStr += String.fromCharCode((temp >> 6) | 192); outputStr += String.fromCharCode((temp & 63) | 128); } //1110xxxx 10xxxxxx 10xxxxxx else if(temp < 65536) { outputStr += String.fromCharCode((temp >> 12) | 224); outputStr += String.fromCharCode(((temp >> 6) & 63) | 128); outputStr += String.fromCharCode((temp & 63) | 128); } //11110xxx 10xxxxxx 10xxxxxx 10xxxxxx else { outputStr += String.fromCharCode((temp >> 18) | 240); outputStr += String.fromCharCode(((temp >> 12) & 63) | 128); outputStr += String.fromCharCode(((temp >> 6) & 63) | 128); outputStr += String.fromCharCode((temp & 63) | 128); } } return outputStr; }
登入後複製
下面是解碼

function utf8Decode(inputStr) { var outputStr = ""; var code1, code2, code3, code4; for(var i = 0; i < inputStr.length; i++) { code1 = inputStr.charCodeAt(i); if(code1 < 128) { outputStr += String.fromCharCode(code1); } else if(code1 < 224) { code2 = inputStr.charCodeAt(++i); outputStr += String.fromCharCode(((code1 & 31) << 6) | (code2 & 63)); } else if(code1 < 240) { code2 = inputStr.charCodeAt(++i); code3 = inputStr.charCodeAt(++i); outputStr += String.fromCharCode(((code1 & 15) << 12) | ((code2 & 63) << 6) | (code3 & 63)); } else { code2 = inputStr.charCodeAt(++i); code3 = inputStr.charCodeAt(++i); code4 = inputStr.charCodeAt(++i); outputStr += String.fromCharCode(((code1 & 7) << 18) | ((code2 & 63) << 12) |((code3 & 63) << 6) | (code2 & 63)); } } return outputStr; }
登入後複製

#相關免費學習推薦:javascript(影片)

以上是學習使用JavaScript實作UTF-8編解碼的詳細內容。更多資訊請關注PHP中文網其他相關文章!

相關標籤:
來源:csdn.net
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
作者最新文章
最新問題
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板
關於我們 免責聲明 Sitemap
PHP中文網:公益線上PHP培訓,幫助PHP學習者快速成長!