您好,登錄后才能下訂單哦!
小編給大家分享一下使用JavaScript實(shí)現(xiàn)UTF-8編解碼的方法,相信大部分人都還不怎么了解,因此分享這篇文章給大家參考一下,希望大家閱讀完這篇文章后大有收獲,下面讓我們一起去了解一下吧!
首先簡(jiǎn)單介紹一下UTF-8。UTF-8以字節(jié)為單位對(duì)Unicode進(jìn)行編碼。 UTF-8的特點(diǎn)是對(duì)不同范圍的字符使用不同長(zhǎng)度的編碼。 對(duì)于0x00-0x7F之間的字符,UTF-8編碼與ASCII編碼完全相同。UTF-8編碼的最大長(zhǎng)度是6個(gè)字節(jié)。 6字節(jié)模板有31個(gè)x,即可以容納31位二進(jìn)制數(shù)字。Unicode的最大碼位0x7FFFFFFF也只有31位。
從Unicode到UTF-8的編碼方式如下:
Unicode編碼(十六進(jìn)制) | UTF-8 字節(jié)流(二進(jìn)制) |
---|---|
000000-00007F | 0xxxxxxx |
000080-0007FF | 110xxxxx 10xxxxxx |
000800-00FFFF | 1110xxxx 10xxxxxx 10xxxxxx |
010000-10FFFF | 11110xxx10xxxxxx10xxxxxx10xxxxxx |
以下是js實(shí)現(xiàn)代碼,首先是編碼
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實(shí)現(xiàn)UTF-8編解碼的方法”這篇文章的所有內(nèi)容,感謝各位的閱讀!相信大家都有了一定的了解,希望分享的內(nèi)容對(duì)大家有所幫助,如果還想學(xué)習(xí)更多知識(shí),歡迎關(guān)注億速云行業(yè)資訊頻道!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如果涉及侵權(quán)請(qǐng)聯(lián)系站長(zhǎng)郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。