Buffer
Properties
BYTES_PER_ELEMENTnumberRequired[toStringTag]"Uint8Array"RequiredbyteLengthnumberRequiredbyteOffsetnumberRequiredlengthnumberRequiredMethods
[iterator]
Returns
at
Takes an integer value and returns the item at that index, allowing for positive and negative integers. Negative integers count back from the last item in the array.
Parameters
indexnumberRequiredReturns
undefined \| numberundefined | numbercompare
Compares buf with target and returns a number indicating whether bufcomes before, after, or is the same as target in sort order.
Comparison is based on the actual sequence of bytes in each Buffer.
0is returned iftargetis the same asbuf1is returned iftargetshould come _before_bufwhen sorted.-1is returned iftargetshould come _after_bufwhen sorted.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from('ABC');
const buf2 = Buffer.from('BCD');
const buf3 = Buffer.from('ABCD');
console.log(buf1.compare(buf1));
// Prints: 0
console.log(buf1.compare(buf2));
// Prints: -1
console.log(buf1.compare(buf3));
// Prints: -1
console.log(buf2.compare(buf1));
// Prints: 1
console.log(buf2.compare(buf3));
// Prints: 1
console.log([buf1, buf2, buf3].sort(Buffer.compare));
// Prints: [ <Buffer 41 42 43>, <Buffer 41 42 43 44>, <Buffer 42 43 44> ]
// (This result is equal to: [buf1, buf3, buf2].)
The optional targetStart, targetEnd, sourceStart, and sourceEndarguments can be used to limit the comparison to specific ranges within targetand buf respectively.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([1, 2, 3, 4, 5, 6, 7, 8, 9]);
const buf2 = Buffer.from([5, 6, 7, 8, 9, 1, 2, 3, 4]);
console.log(buf1.compare(buf2, 5, 9, 0, 4));
// Prints: 0
console.log(buf1.compare(buf2, 0, 6, 4));
// Prints: -1
console.log(buf1.compare(buf2, 5, 6, 5));
// Prints: 1
ERR_OUT_OF_RANGE is thrown if targetStart < 0, sourceStart < 0,targetEnd > target.byteLength, or sourceEnd > source.byteLength.
Parameters
targetUint8ArrayRequiredBuffer or Uint8Array with which to compare buf.targetStartnumbertarget at which to begin comparison.targetEndnumbertarget at which to end comparison (not inclusive).sourceStartnumberbuf at which to begin comparison.sourceEndnumberbuf at which to end comparison (not inclusive).Returns
0 \| 1 \| -10 | 1 | -1Since
v0.11.13
copy
Copies data from a region of buf to a region in target, even if the targetmemory region overlaps with buf.
TypedArray.prototype.set() performs the same operation, and is available
for all TypedArrays, including Node.js Buffers, although it takes
different function arguments.
import { Buffer } from 'node:buffer';
// Create two `Buffer` instances.
const buf1 = Buffer.allocUnsafe(26);
const buf2 = Buffer.allocUnsafe(26).fill('!');
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf1[i] = i + 97;
}
// Copy `buf1` bytes 16 through 19 into `buf2` starting at byte 8 of `buf2`.
buf1.copy(buf2, 8, 16, 20);
// This is equivalent to:
// buf2.set(buf1.subarray(16, 20), 8);
console.log(buf2.toString('ascii', 0, 25));
// Prints: !!!!!!!!qrst!!!!!!!!!!!!!
import { Buffer } from 'node:buffer';
// Create a `Buffer` and copy data from one region to an overlapping region
// within the same `Buffer`.
const buf = Buffer.allocUnsafe(26);
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf[i] = i + 97;
}
buf.copy(buf, 0, 4, 10);
console.log(buf.toString());
// Prints: efghijghijklmnopqrstuvwxyz
Parameters
targetUint8ArrayRequiredBuffer or Uint8Array to copy into.targetStartnumbertarget at which to begin writing.sourceStartnumberbuf from which to begin copying.sourceEndnumberbuf at which to stop copying (not inclusive).Returns
numbernumberSince
v0.1.90
copyWithin
Returns the this object after copying a section of the array identified by start and end to the same array starting at position target
Parameters
targetnumberRequiredstartnumberRequiredendnumberReturns
entries
Creates and returns an iterator of [index, byte] pairs from the contents
of buf.
Returns
Since
v1.1.0
equals
Returns true if both buf and otherBuffer have exactly the same bytes,false otherwise. Equivalent to buf.compare(otherBuffer) === 0.
Parameters
otherBufferUint8ArrayRequiredBuffer or Uint8Array with which to compare buf.Returns
booleanbooleanSince
v0.11.13
every
Determines whether all the members of an array satisfy the specified test.
Parameters
predicate(value: number, index: number, array: Uint8Array) => unknownRequiredthisArganyReturns
booleanbooleanfill
Fills buf with the specified value. If the offset and end are not given,
the entire buf will be filled:
import { Buffer } from 'node:buffer';
// Fill a `Buffer` with the ASCII character 'h'.
const b = Buffer.allocUnsafe(50).fill('h');
console.log(b.toString());
// Prints: hhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhhh
// Fill a buffer with empty string
const c = Buffer.allocUnsafe(5).fill('');
console.log(c.fill(''));
// Prints: <Buffer 00 00 00 00 00>
value is coerced to a uint32 value if it is not a string, Buffer, or
integer. If the resulting integer is greater than 255 (decimal), buf will be
filled with value & 255.
If the final write of a fill() operation falls on a multi-byte character,
then only the bytes of that character that fit into buf are written:
If value contains invalid characters, it is truncated; if no valid
fill data remains, an exception is thrown:
Parameters
valuestring | number | Uint8ArrayRequiredbuf. Empty value (string, Uint8Array, Buffer) is coerced to 0.offsetnumberbuf.endnumberbuf (not inclusive).encodingBufferEncodingvalue if value is a string.Returns
buf.Since
v0.5.0
filter
Returns the elements of an array that meet the condition specified in a callback function.
Parameters
predicate(value: number, index: number, array: Uint8Array) => anyRequiredthisArganyReturns
Uint8ArrayUint8ArrayRequiredfind
Returns the value of the first element in the array where predicate is true, and undefined otherwise.
Parameters
predicate(value: number, index: number, obj: Uint8Array) => booleanRequiredthisArganyReturns
undefined \| numberundefined | numberfindIndex
Returns the index of the first element in the array where predicate is true, and -1 otherwise.
Parameters
predicate(value: number, index: number, obj: Uint8Array) => booleanRequiredthisArganyReturns
numbernumberforEach
Performs the specified action for each element in an array.
Parameters
callbackfn(value: number, index: number, array: Uint8Array) => voidRequiredthisArganyReturns
voidvoidincludes
Equivalent to buf.indexOf() !== -1.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('this is a buffer');
console.log(buf.includes('this'));
// Prints: true
console.log(buf.includes('is'));
// Prints: true
console.log(buf.includes(Buffer.from('a buffer')));
// Prints: true
console.log(buf.includes(97));
// Prints: true (97 is the decimal ASCII value for 'a')
console.log(buf.includes(Buffer.from('a buffer example')));
// Prints: false
console.log(buf.includes(Buffer.from('a buffer example').slice(0, 8)));
// Prints: true
console.log(buf.includes('this', 4));
// Prints: false
Parameters
byteOffsetnumberbuf. If negative, then offset is calculated from the end of buf.encodingBufferEncodingvalue is a string, this is its encoding.Returns
booleanbooleantrue if value was found in buf, false otherwise.Since
v5.3.0
indexOf
If value is:
- a string,
valueis interpreted according to the character encoding inencoding. - a
BufferorUint8Array,valuewill be used in its entirety. To compare a partialBuffer, usebuf.subarray. - a number,
valuewill be interpreted as an unsigned 8-bit integer value between0and255.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('this is a buffer');
console.log(buf.indexOf('this'));
// Prints: 0
console.log(buf.indexOf('is'));
// Prints: 2
console.log(buf.indexOf(Buffer.from('a buffer')));
// Prints: 8
console.log(buf.indexOf(97));
// Prints: 8 (97 is the decimal ASCII value for 'a')
console.log(buf.indexOf(Buffer.from('a buffer example')));
// Prints: -1
console.log(buf.indexOf(Buffer.from('a buffer example').slice(0, 8)));
// Prints: 8
const utf16Buffer = Buffer.from('\u039a\u0391\u03a3\u03a3\u0395', 'utf16le');
console.log(utf16Buffer.indexOf('\u03a3', 0, 'utf16le'));
// Prints: 4
console.log(utf16Buffer.indexOf('\u03a3', -4, 'utf16le'));
// Prints: 6
If value is not a string, number, or Buffer, this method will throw aTypeError. If value is a number, it will be coerced to a valid byte value,
an integer between 0 and 255.
If byteOffset is not a number, it will be coerced to a number. If the result
of coercion is NaN or 0, then the entire buffer will be searched. This
behavior matches String.prototype.indexOf().
import { Buffer } from 'node:buffer';
const b = Buffer.from('abcdef');
// Passing a value that's a number, but not a valid byte.
// Prints: 2, equivalent to searching for 99 or 'c'.
console.log(b.indexOf(99.9));
console.log(b.indexOf(256 + 99));
// Passing a byteOffset that coerces to NaN or 0.
// Prints: 1, searching the whole buffer.
console.log(b.indexOf('b', undefined));
console.log(b.indexOf('b', {}));
console.log(b.indexOf('b', null));
console.log(b.indexOf('b', []));
If value is an empty string or empty Buffer and byteOffset is less
than buf.length, byteOffset will be returned. If value is empty andbyteOffset is at least buf.length, buf.length will be returned.
Parameters
valuestring | number | Uint8ArrayRequiredbyteOffsetnumberbuf. If negative, then offset is calculated from the end of buf.encodingBufferEncodingvalue is a string, this is the encoding used to determine the binary representation of the string that will be searched for in buf.Returns
numbernumbervalue in buf, or -1 if buf does not contain value.Since
v1.5.0
join
Adds all the elements of an array separated by the specified separator string.
Parameters
separatorstringReturns
stringstringkeys
Creates and returns an iterator of buf keys (indices).
Returns
Since
v1.1.0
lastIndexOf
Identical to buf.indexOf(), except the last occurrence of value is found
rather than the first occurrence.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('this buffer is a buffer');
console.log(buf.lastIndexOf('this'));
// Prints: 0
console.log(buf.lastIndexOf('buffer'));
// Prints: 17
console.log(buf.lastIndexOf(Buffer.from('buffer')));
// Prints: 17
console.log(buf.lastIndexOf(97));
// Prints: 15 (97 is the decimal ASCII value for 'a')
console.log(buf.lastIndexOf(Buffer.from('yolo')));
// Prints: -1
console.log(buf.lastIndexOf('buffer', 5));
// Prints: 5
console.log(buf.lastIndexOf('buffer', 4));
// Prints: -1
const utf16Buffer = Buffer.from('\u039a\u0391\u03a3\u03a3\u0395', 'utf16le');
console.log(utf16Buffer.lastIndexOf('\u03a3', undefined, 'utf16le'));
// Prints: 6
console.log(utf16Buffer.lastIndexOf('\u03a3', -5, 'utf16le'));
// Prints: 4
If value is not a string, number, or Buffer, this method will throw aTypeError. If value is a number, it will be coerced to a valid byte value,
an integer between 0 and 255.
If byteOffset is not a number, it will be coerced to a number. Any arguments
that coerce to NaN, like {} or undefined, will search the whole buffer.
This behavior matches String.prototype.lastIndexOf().
import { Buffer } from 'node:buffer';
const b = Buffer.from('abcdef');
// Passing a value that's a number, but not a valid byte.
// Prints: 2, equivalent to searching for 99 or 'c'.
console.log(b.lastIndexOf(99.9));
console.log(b.lastIndexOf(256 + 99));
// Passing a byteOffset that coerces to NaN.
// Prints: 1, searching the whole buffer.
console.log(b.lastIndexOf('b', undefined));
console.log(b.lastIndexOf('b', {}));
// Passing a byteOffset that coerces to 0.
// Prints: -1, equivalent to passing 0.
console.log(b.lastIndexOf('b', null));
console.log(b.lastIndexOf('b', []));
If value is an empty string or empty Buffer, byteOffset will be returned.
Parameters
valuestring | number | Uint8ArrayRequiredbyteOffsetnumberbuf. If negative, then offset is calculated from the end of buf.encodingBufferEncodingvalue is a string, this is the encoding used to determine the binary representation of the string that will be searched for in buf.Returns
numbernumbervalue in buf, or -1 if buf does not contain value.Since
v6.0.0
map
Calls a defined callback function on each element of an array, and returns an array that contains the results.
Parameters
callbackfn(value: number, index: number, array: Uint8Array) => numberRequiredthisArganyReturns
Uint8ArrayUint8ArrayRequiredreadBigInt64BE
Reads a signed, big-endian 64-bit integer from buf at the specified offset.
Integers read from a Buffer are interpreted as two's complement signed
values.
Parameters
offsetnumber0 <= offset <= buf.length - 8.Returns
bigintbigintSince
v12.0.0, v10.20.0
readBigInt64LE
Reads a signed, little-endian 64-bit integer from buf at the specifiedoffset.
Integers read from a Buffer are interpreted as two's complement signed
values.
Parameters
offsetnumber0 <= offset <= buf.length - 8.Returns
bigintbigintSince
v12.0.0, v10.20.0
readBigUInt64BE
Reads an unsigned, big-endian 64-bit integer from buf at the specifiedoffset.
This function is also available under the readBigUint64BE alias.
Parameters
offsetnumber0 <= offset <= buf.length - 8.Returns
bigintbigintSince
v12.0.0, v10.20.0
readBigUInt64LE
Reads an unsigned, little-endian 64-bit integer from buf at the specifiedoffset.
This function is also available under the readBigUint64LE alias.
Parameters
offsetnumber0 <= offset <= buf.length - 8.Returns
bigintbigintSince
v12.0.0, v10.20.0
readBigUint64BE
Parameters
offsetnumberReturns
bigintbigintAlias
Buffer.readBigUInt64BE
Since
v14.10.0, v12.19.0
readBigUint64LE
Parameters
offsetnumberReturns
bigintbigintAlias
Buffer.readBigUInt64LE
Since
v14.10.0, v12.19.0
readDoubleBE
Reads a 64-bit, big-endian double from buf at the specified offset.
Parameters
offsetnumber0 <= offset <= buf.length - 8.Returns
numbernumberSince
v0.11.15
readDoubleLE
Reads a 64-bit, little-endian double from buf at the specified offset.
Parameters
offsetnumber0 <= offset <= buf.length - 8.Returns
numbernumberSince
v0.11.15
readFloatBE
Reads a 32-bit, big-endian float from buf at the specified offset.
Parameters
offsetnumber0 <= offset <= buf.length - 4.Returns
numbernumberSince
v0.11.15
readFloatLE
Reads a 32-bit, little-endian float from buf at the specified offset.
Parameters
offsetnumber0 <= offset <= buf.length - 4.Returns
numbernumberSince
v0.11.15
readInt16BE
Reads a signed, big-endian 16-bit integer from buf at the specified offset.
Integers read from a Buffer are interpreted as two's complement signed values.
Parameters
offsetnumber0 <= offset <= buf.length - 2.Returns
numbernumberSince
v0.5.5
readInt16LE
Reads a signed, little-endian 16-bit integer from buf at the specifiedoffset.
Integers read from a Buffer are interpreted as two's complement signed values.
Parameters
offsetnumber0 <= offset <= buf.length - 2.Returns
numbernumberSince
v0.5.5
readInt32BE
Reads a signed, big-endian 32-bit integer from buf at the specified offset.
Integers read from a Buffer are interpreted as two's complement signed values.
Parameters
offsetnumber0 <= offset <= buf.length - 4.Returns
numbernumberSince
v0.5.5
readInt32LE
Reads a signed, little-endian 32-bit integer from buf at the specifiedoffset.
Integers read from a Buffer are interpreted as two's complement signed values.
Parameters
offsetnumber0 <= offset <= buf.length - 4.Returns
numbernumberSince
v0.5.5
readInt8
Reads a signed 8-bit integer from buf at the specified offset.
Integers read from a Buffer are interpreted as two's complement signed values.
Parameters
offsetnumber0 <= offset <= buf.length - 1.Returns
numbernumberSince
v0.5.0
readIntBE
Reads byteLength number of bytes from buf at the specified offsetand interprets the result as a big-endian, two's complement signed value
supporting up to 48 bits of accuracy.
import { Buffer } from 'node:buffer';
const buf = Buffer.from([0x12, 0x34, 0x56, 0x78, 0x90, 0xab]);
console.log(buf.readIntBE(0, 6).toString(16));
// Prints: 1234567890ab
console.log(buf.readIntBE(1, 6).toString(16));
// Throws ERR_OUT_OF_RANGE.
console.log(buf.readIntBE(1, 0).toString(16));
// Throws ERR_OUT_OF_RANGE.
Parameters
offsetnumberRequired0 <= offset <= buf.length - byteLength.byteLengthnumberRequired0 < byteLength <= 6.Returns
numbernumberSince
v0.11.15
readIntLE
Reads byteLength number of bytes from buf at the specified offsetand interprets the result as a little-endian, two's complement signed value
supporting up to 48 bits of accuracy.
Parameters
offsetnumberRequired0 <= offset <= buf.length - byteLength.byteLengthnumberRequired0 < byteLength <= 6.Returns
numbernumberSince
v0.11.15
readUInt16BE
Reads an unsigned, big-endian 16-bit integer from buf at the specifiedoffset.
This function is also available under the readUint16BE alias.
Parameters
offsetnumber0 <= offset <= buf.length - 2.Returns
numbernumberSince
v0.5.5
readUInt16LE
Reads an unsigned, little-endian 16-bit integer from buf at the specifiedoffset.
This function is also available under the readUint16LE alias.
Parameters
offsetnumber0 <= offset <= buf.length - 2.Returns
numbernumberSince
v0.5.5
readUInt32BE
Reads an unsigned, big-endian 32-bit integer from buf at the specifiedoffset.
This function is also available under the readUint32BE alias.
Parameters
offsetnumber0 <= offset <= buf.length - 4.Returns
numbernumberSince
v0.5.5
readUInt32LE
Reads an unsigned, little-endian 32-bit integer from buf at the specifiedoffset.
This function is also available under the readUint32LE alias.
Parameters
offsetnumber0 <= offset <= buf.length - 4.Returns
numbernumberSince
v0.5.5
readUInt8
Reads an unsigned 8-bit integer from buf at the specified offset.
This function is also available under the readUint8 alias.
Parameters
offsetnumber0 <= offset <= buf.length - 1.Returns
numbernumberSince
v0.5.0
readUIntBE
Reads byteLength number of bytes from buf at the specified offsetand interprets the result as an unsigned big-endian integer supporting
up to 48 bits of accuracy.
This function is also available under the readUintBE alias.
Parameters
offsetnumberRequired0 <= offset <= buf.length - byteLength.byteLengthnumberRequired0 < byteLength <= 6.Returns
numbernumberSince
v0.11.15
readUIntLE
Reads byteLength number of bytes from buf at the specified offsetand interprets the result as an unsigned, little-endian integer supporting
up to 48 bits of accuracy.
This function is also available under the readUintLE alias.
Parameters
offsetnumberRequired0 <= offset <= buf.length - byteLength.byteLengthnumberRequired0 < byteLength <= 6.Returns
numbernumberSince
v0.11.15
readUint16BE
Parameters
offsetnumberReturns
numbernumberAlias
Buffer.readUInt16BE
Since
v14.9.0, v12.19.0
readUint16LE
Parameters
offsetnumberReturns
numbernumberAlias
Buffer.readUInt16LE
Since
v14.9.0, v12.19.0
readUint32BE
Parameters
offsetnumberReturns
numbernumberAlias
Buffer.readUInt32BE
Since
v14.9.0, v12.19.0
readUint32LE
Parameters
offsetnumberReturns
numbernumberAlias
Buffer.readUInt32LE
Since
v14.9.0, v12.19.0
readUint8
Parameters
offsetnumberReturns
numbernumberAlias
Buffer.readUInt8
Since
v14.9.0, v12.19.0
readUintBE
Parameters
offsetnumberRequiredbyteLengthnumberRequiredReturns
numbernumberAlias
Buffer.readUIntBE
Since
v14.9.0, v12.19.0
readUintLE
Parameters
offsetnumberRequiredbyteLengthnumberRequiredReturns
numbernumberAlias
Buffer.readUIntLE
Since
v14.9.0, v12.19.0
reduce
**reduce**(callbackfn): number
Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
Parameters
callbackfn(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredReturns
numbernumber**reduce**(callbackfn, initialValue): number
Parameters
callbackfn(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredinitialValuenumberRequiredReturns
numbernumber**reduce**<TypeParameter U>(callbackfn, initialValue): U
Calls the specified callback function for all the elements in an array. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
Parameters
callbackfn(previousValue: U, currentValue: number, currentIndex: number, array: Uint8Array) => URequiredinitialValueURequiredReturns
reduceRight
**reduceRight**(callbackfn): number
Calls the specified callback function for all the elements in an array, in descending order. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
Parameters
callbackfn(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredReturns
numbernumber**reduceRight**(callbackfn, initialValue): number
Parameters
callbackfn(previousValue: number, currentValue: number, currentIndex: number, array: Uint8Array) => numberRequiredinitialValuenumberRequiredReturns
numbernumber**reduceRight**<TypeParameter U>(callbackfn, initialValue): U
Calls the specified callback function for all the elements in an array, in descending order. The return value of the callback function is the accumulated result, and is provided as an argument in the next call to the callback function.
Parameters
callbackfn(previousValue: U, currentValue: number, currentIndex: number, array: Uint8Array) => URequiredinitialValueURequiredReturns
reverse
Returns
set
Sets a value or an array of values.
Parameters
offsetnumberReturns
voidvoidslice
Returns a new Buffer that references the same memory as the original, but
offset and cropped by the start and end indices.
This method is not compatible with the Uint8Array.prototype.slice(),
which is a superclass of Buffer. To copy the slice, useUint8Array.prototype.slice().
import { Buffer } from 'node:buffer';
const buf = Buffer.from('buffer');
const copiedBuf = Uint8Array.prototype.slice.call(buf);
copiedBuf[0]++;
console.log(copiedBuf.toString());
// Prints: cuffer
console.log(buf.toString());
// Prints: buffer
// With buf.slice(), the original buffer is modified.
const notReallyCopiedBuf = buf.slice();
notReallyCopiedBuf[0]++;
console.log(notReallyCopiedBuf.toString());
// Prints: cuffer
console.log(buf.toString());
// Also prints: cuffer (!)
Parameters
startnumberBuffer will start.endnumberBuffer will end (not inclusive).Returns
Since
v0.3.0
Deprecated
Use subarray instead.
some
Determines whether the specified callback function returns true for any element of an array.
Parameters
predicate(value: number, index: number, array: Uint8Array) => unknownRequiredthisArganyReturns
booleanbooleansort
Sorts an array.
Parameters
compareFn(a: number, b: number) => numberts [11,2,22,1].sort((a, b) => a - b) Returns
subarray
Returns a new Buffer that references the same memory as the original, but
offset and cropped by the start and end indices.
Specifying end greater than buf.length will return the same result as
that of end equal to buf.length.
This method is inherited from TypedArray.prototype.subarray().
Modifying the new Buffer slice will modify the memory in the original Bufferbecause the allocated memory of the two objects overlap.
import { Buffer } from 'node:buffer';
// Create a `Buffer` with the ASCII alphabet, take a slice, and modify one byte
// from the original `Buffer`.
const buf1 = Buffer.allocUnsafe(26);
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf1[i] = i + 97;
}
const buf2 = buf1.subarray(0, 3);
console.log(buf2.toString('ascii', 0, buf2.length));
// Prints: abc
buf1[0] = 33;
console.log(buf2.toString('ascii', 0, buf2.length));
// Prints: !bc
Specifying negative indexes causes the slice to be generated relative to the
end of buf rather than the beginning.
import { Buffer } from 'node:buffer';
const buf = Buffer.from('buffer');
console.log(buf.subarray(-6, -1).toString());
// Prints: buffe
// (Equivalent to buf.subarray(0, 5).)
console.log(buf.subarray(-6, -2).toString());
// Prints: buff
// (Equivalent to buf.subarray(0, 4).)
console.log(buf.subarray(-5, -2).toString());
// Prints: uff
// (Equivalent to buf.subarray(1, 4).)
Parameters
startnumberBuffer will start.endnumberBuffer will end (not inclusive).Returns
Since
v3.0.0
swap16
Interprets buf as an array of unsigned 16-bit integers and swaps the
byte order _in-place_. Throws ERR_INVALID_BUFFER_SIZE if buf.length is not a multiple of 2.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
console.log(buf1);
// Prints: <Buffer 01 02 03 04 05 06 07 08>
buf1.swap16();
console.log(buf1);
// Prints: <Buffer 02 01 04 03 06 05 08 07>
const buf2 = Buffer.from([0x1, 0x2, 0x3]);
buf2.swap16();
// Throws ERR_INVALID_BUFFER_SIZE.
One convenient use of buf.swap16() is to perform a fast in-place conversion
between UTF-16 little-endian and UTF-16 big-endian:
Returns
buf.Since
v5.10.0
swap32
Interprets buf as an array of unsigned 32-bit integers and swaps the
byte order _in-place_. Throws ERR_INVALID_BUFFER_SIZE if buf.length is not a multiple of 4.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
console.log(buf1);
// Prints: <Buffer 01 02 03 04 05 06 07 08>
buf1.swap32();
console.log(buf1);
// Prints: <Buffer 04 03 02 01 08 07 06 05>
const buf2 = Buffer.from([0x1, 0x2, 0x3]);
buf2.swap32();
// Throws ERR_INVALID_BUFFER_SIZE.
Returns
buf.Since
v5.10.0
swap64
Interprets buf as an array of 64-bit numbers and swaps byte order _in-place_.
Throws ERR_INVALID_BUFFER_SIZE if buf.length is not a multiple of 8.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5, 0x6, 0x7, 0x8]);
console.log(buf1);
// Prints: <Buffer 01 02 03 04 05 06 07 08>
buf1.swap64();
console.log(buf1);
// Prints: <Buffer 08 07 06 05 04 03 02 01>
const buf2 = Buffer.from([0x1, 0x2, 0x3]);
buf2.swap64();
// Throws ERR_INVALID_BUFFER_SIZE.
Returns
buf.Since
v6.3.0
toJSON
Returns a JSON representation of buf. JSON.stringify() implicitly calls
this function when stringifying a Buffer instance.
Buffer.from() accepts objects in the format returned from this method.
In particular, Buffer.from(buf.toJSON()) works like Buffer.from(buf).
import { Buffer } from 'node:buffer';
const buf = Buffer.from([0x1, 0x2, 0x3, 0x4, 0x5]);
const json = JSON.stringify(buf);
console.log(json);
// Prints: {"type":"Buffer","data":[1,2,3,4,5]}
const copy = JSON.parse(json, (key, value) => {
return value && value.type === 'Buffer' ?
Buffer.from(value) :
value;
});
console.log(copy);
// Prints: <Buffer 01 02 03 04 05>
Returns
objectobjectdatanumber[]Requiredtype"Buffer"RequiredSince
v0.9.2
toLocaleString
Converts a number to a string by using the current locale.
Returns
stringstringtoString
Decodes buf to a string according to the specified character encoding inencoding. start and end may be passed to decode only a subset of buf.
If encoding is 'utf8' and a byte sequence in the input is not valid UTF-8,
then each invalid byte is replaced with the replacement character U+FFFD.
The maximum length of a string instance (in UTF-16 code units) is available as constants.MAX_STRING_LENGTH.
import { Buffer } from 'node:buffer';
const buf1 = Buffer.allocUnsafe(26);
for (let i = 0; i < 26; i++) {
// 97 is the decimal ASCII value for 'a'.
buf1[i] = i + 97;
}
console.log(buf1.toString('utf8'));
// Prints: abcdefghijklmnopqrstuvwxyz
console.log(buf1.toString('utf8', 0, 5));
// Prints: abcde
const buf2 = Buffer.from('tést');
console.log(buf2.toString('hex'));
// Prints: 74c3a97374
console.log(buf2.toString('utf8', 0, 3));
// Prints: té
console.log(buf2.toString(undefined, 0, 3));
// Prints: té
Parameters
encodingBufferEncodingstartnumberendnumberReturns
stringstringSince
v0.1.90
valueOf
Returns the primitive value of the specified object.
Returns
Uint8ArrayUint8ArrayRequiredvalues
Creates and returns an iterator for buf values (bytes). This function is
called automatically when a Buffer is used in a for..of statement.
Returns
Since
v1.1.0
write
**write**(string, encoding?): number
Writes string to buf at offset according to the character encoding inencoding. The length parameter is the number of bytes to write. If buf did
not contain enough space to fit the entire string, only part of string will be
written. However, partially encoded characters will not be written.
import { Buffer } from 'node:buffer';
const buf = Buffer.alloc(256);
const len = buf.write('\u00bd + \u00bc = \u00be', 0);
console.log(`${len} bytes: ${buf.toString('utf8', 0, len)}`);
// Prints: 12 bytes: ½ + ¼ = ¾
const buffer = Buffer.alloc(10);
const length = buffer.write('abcd', 8);
console.log(`${length} bytes: ${buffer.toString('utf8', 8, 10)}`);
// Prints: 2 bytes : ab
Parameters
stringstringRequiredbuf.encodingBufferEncodingstring.Returns
numbernumberSince
v0.1.90
**write**(string, offset, encoding?): number
Parameters
Returns
numbernumber**write**(string, offset, length, encoding?): number
Parameters
Returns
numbernumberwriteBigInt64BE
Writes value to buf at the specified offset as big-endian.
value is interpreted and written as a two's complement signed integer.
Parameters
valuebigintRequiredbuf.offsetnumber0 <= offset <= buf.length - 8.Returns
numbernumberoffset plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigInt64LE
Writes value to buf at the specified offset as little-endian.
value is interpreted and written as a two's complement signed integer.
Parameters
valuebigintRequiredbuf.offsetnumber0 <= offset <= buf.length - 8.Returns
numbernumberoffset plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigUInt64BE
Writes value to buf at the specified offset as big-endian.
This function is also available under the writeBigUint64BE alias.
Parameters
valuebigintRequiredbuf.offsetnumber0 <= offset <= buf.length - 8.Returns
numbernumberoffset plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigUInt64LE
Writes value to buf at the specified offset as little-endian
This function is also available under the writeBigUint64LE alias.
Parameters
valuebigintRequiredbuf.offsetnumber0 <= offset <= buf.length - 8.Returns
numbernumberoffset plus the number of bytes written.Since
v12.0.0, v10.20.0
writeBigUint64BE
Parameters
valuebigintRequiredoffsetnumberReturns
numbernumberAlias
Buffer.writeBigUInt64BE
Since
v14.10.0, v12.19.0
writeBigUint64LE
Parameters
valuebigintRequiredoffsetnumberReturns
numbernumberAlias
Buffer.writeBigUInt64LE