在日常的開發中,我們經常需要將字串轉換成 UTF-8 格式,因為 UTF-8 是一種通用的字符編碼方式,它支援多語言字符,包括中文、日文、韓文等等。 JavaScript 是一門常用的腳本語言,它可以幫助我們實現這個轉換過程。
本文將會從以下幾個面向介紹如何在JavaScript 中將字串轉換成UTF-8 格式:
function utf8Encode(str) { let encodedStr = encodeURIComponent(str).replace(/%([0-9A-F]{2})/g, (match, p1) => { return String.fromCharCode(parseInt(p1, 16)); }); let utf8Str = ""; for (let i = 0; i < encodedStr.length; i++) { let charCode = encodedStr.charCodeAt(i); if (charCode < 128) { utf8Str += String.fromCharCode(charCode); } else if (charCode < 2048) { utf8Str += String.fromCharCode((charCode >> 6) | 192); utf8Str += String.fromCharCode((charCode & 63) | 128); } else { utf8Str += String.fromCharCode((charCode >> 12) | 224); utf8Str += String.fromCharCode(((charCode >> 6) & 63) | 128); utf8Str += String.fromCharCode((charCode & 63) | 128); } } return utf8Str; }其中, encodeURIComponent() 函數用於把字串轉換成URI 編碼,replace() 函數則用於將每個字元的URI 編碼按照UTF-8 格式拼接成最終的字串。 解碼函數則是使用decodeURIComponent() 函數對經過編碼的字串進行解碼,範例程式碼如下:
function utf8Decode(utf8Str) { let decodedStr = ""; let i = 0; while (i < utf8Str.length) { let charCode = utf8Str.charCodeAt(i); if (charCode < 128) { decodedStr += String.fromCharCode(charCode); i++; } else if (charCode >= 192 && charCode < 224) { decodedStr += String.fromCharCode(((charCode & 31) << 6) | (utf8Str.charCodeAt(i + 1) & 63)); i += 2; } else { decodedStr += String.fromCharCode(((charCode & 15) << 12) | ((utf8Str.charCodeAt(i + 1) & 63) << 6) | (utf8Str.charCodeAt(i + 2) & 63)); i += 3; } } return decodeURIComponent(decodedStr); }
const iconv = require("iconv-lite"); let utf8Str = "欢迎使用 iconv-lite 库"; let buf = iconv.encode(utf8Str, "utf8"); // 转成 UTF-8 Buffer let gbkStr = iconv.decode(buf, "gbk"); // 转成 GBK 编码字符串在上述程式碼中,我們使用iconv.encode() 函式將字串轉成UTF-8 編碼的Buffer,再使用iconv.decode() 函數將Buffer 轉成對應編碼的字串。需要注意的是,使用iconv-lite 庫需要先透過npm 安裝,安裝方式為:
npm install iconv-lite總結#本文介紹如何在JavaScript 中將字串轉換成UTF-8 格式。我們了解了 UTF-8 編碼方式,透過編碼和解碼函數實現了字串轉 UTF-8 的簡單方法,並介紹了使用 iconv-lite 庫完成整個應用的轉碼任務。在實際開發中,根據實際需求選擇適合的方法可以減少開發成本,並提高工作效率。
以上是如何在JavaScript中將字串轉成UTF-8格式的詳細內容。更多資訊請關注PHP中文網其他相關文章!