這篇文章主要為大家展示了Node.js API中怎么使用string_decoder,內容簡而易懂,希望大家可以學習一下,學習完之后肯定會有收獲的,下面讓小編帶大家一起來看看吧。
創新互聯專注于中大型企業的成都網站設計、網站建設、外貿網站建設和網站改版、網站營銷服務,追求商業策劃與數據分析、創意藝術與技術開發的融合,累計客戶千余家,服務滿意度達97%。幫助廣大客戶順利對接上互聯網浪潮,準確優選出符合自己需要的互聯網運用,我們將一直專注成都品牌網站建設和互聯網程序開發,在前進的路上,與客戶一起成長!string_decoder 模塊提供了一個 API,用于把 Buffer 對象解碼成字符串。
對于參數末尾不完整的多字節字符,string_decoder會將其保存在內部的buffer中,當再次解碼時,補充到參數開頭。
通過 const { StringDecoder } = require(‘string_decoder'); 的方式引用string_decoder模塊。
目錄:
new StringDecoder([encoding])
說明:
創建一個新的StringDecoder實例,可傳遞encoding參數作為字符編碼格式,默認為'utf8′
stringDecoder.write(buffer)
說明:
返回一個解碼后的字符串,并確保返回的字符串不包含殘缺的多字節字符,殘缺的多字節字符會被保存在一個內部的 buffer 中,
用于下次調用 stringDecoder.write() 或 stringDecoder.end()。
buffer:待解碼的Buffer
demo:
const decoder = new StringDecoder('utf8'); //字符的16進制小于0x80屬于單字節 let outString = decoder.write(Buffer.from([0x78, 0x69, 0x61, 0x6f, 0x71, 0x69, 0x61, 0x6e, 0x67])); console.log(outString); //xiaoqiang //字符的16進制大于0x80屬于雙字節 outString = decoder.write(Buffer.from([0xC2, 0xA2])); console.log(outString); //¢ //單雙字節混合,置于末尾 outString = decoder.write(Buffer.from([0x78, 0x69, 0x61, 0x6f, 0x71, 0x69, 0x61, 0x6e, 0x67, 0xC2])); console.log(outString); //xiaoqiang outString = decoder.write(Buffer.from([0xA2])); console.log(outString); //¢ //單雙字節混合,置于中間 outString = decoder.write(Buffer.from([0x78, 0x69, 0x61, 0x6f, 0x71, 0xC2, 0x69, 0x61, 0x6e, 0x67])); console.log(outString); //xiaoq?iang outString = decoder.write(Buffer.from([0xA2])); console.log(outString); //? //單雙字節混合,置于開始 outString = decoder.write(Buffer.from([0xC2, 0x78, 0x69, 0x61, 0x6f, 0x71, 0x69, 0x61, 0x6e, 0x67])); console.log(outString); //?xiaoqiang outString = decoder.write(Buffer.from([0xA2])); console.log(outString); //? //單雙字節混合,置于末尾 outString = decoder.write(Buffer.from([0x78, 0x69, 0x61, 0x6f, 0x71, 0x69, 0x61, 0x6e, 0x67, 0xC2])); console.log(outString); //xiaoqiang outString = decoder.write(Buffer.from([0x78,0xA2])); console.log(outString); //?x?
分享文章:Node.jsAPI中怎么使用string_decoder-創新互聯
路徑分享:http://vcdvsql.cn/article32/djhgsc.html
成都網站建設公司_創新互聯,為您提供網頁設計公司、建站公司、軟件開發、網站設計、動態網站、定制開發
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯