该方法将以字符串形式返回留在内部缓冲区中的任何剩余输入。保留不完整并表示 UTF-8 和 UTF-16 字符的字节将替换为适合字符编码的替换字符。stringDecoder.end()
StringDecoder.write()如果提供了任何缓冲区参数,则在返回剩余输入之前调用方法。一旦方法被调用,stringDecoder就可以重新用于获取新的输入end()。
stringDecoder.end( [buffer] )
buffer - 此参数接受要解码的字节的输入。它可以将缓冲区、TypedArray 或 DataView 作为输入参数。
创建一个名为“ end.js ”的文件并复制以下代码。创建文件后,使用命令“ node end.js ”运行此代码,如下例所示
// stringDecoder.end() 方法演示示例 // 导入 string_decoder 模块 const { StringDecoder } = require("string_decoder"); // 定义解码器类型 const decoder = new StringDecoder("utf-8"); // 将文本转换为缓冲区 const text = Buffer.from("nhooo", "utf-8"); // 使用 end() 方法从缓冲区获取文本 let decoded_text = decoder.end(text); // 打印解码后的文本 console.log("解码文本:", decoded_text);输出结果
解码文本: nhooo
// stringDecoder.end() 方法演示示例 // 导入 string_decoder 模块 const { StringDecoder } = require("string_decoder"); // 定义解码器类型 const decoder = new StringDecoder("utf-8"); // 欧元符号:[0xE2, 0x82, 0xAC] console.log("解码欧元符号:"); // 在解码器中写入欧元值 decoder.write(Buffer.from([0xE2])); decoder.write(Buffer.from([0x82])); // 使用 end() 方法打印符号 console.log(decoder.end(Buffer.from([0xAC])));输出结果
€