Skip to main content
BufferConstructor.byteLength - buffer - Node documentation
method BufferConstructor.byteLength

Usage in Deno

import { type BufferConstructor } from "node:buffer";
BufferConstructor.byteLength(
string:
string
| Buffer
| ArrayBufferView
| ArrayBuffer
| SharedArrayBuffer
,
encoding?: BufferEncoding,
): number

Returns the byte length of a string when encoded using encoding. This is not the same as String.prototype.length, which does not account for the encoding that is used to convert the string into bytes.

For 'base64', 'base64url', and 'hex', this function assumes valid input. For strings that contain non-base64/hex-encoded data (e.g. whitespace), the return value might be greater than the length of a Buffer created from the string.

import { Buffer } from 'node:buffer';

const str = '\u00bd + \u00bc = \u00be';

console.log(`${str}: ${str.length} characters, ` +
            `${Buffer.byteLength(str, 'utf8')} bytes`);
// Prints: ½ + ¼ = ¾: 9 characters, 12 bytes

When string is a Buffer/DataView/[TypedArray](https://developer.mozilla.org/en-US/docs/Web/JavaScript/- Reference/Global_Objects/TypedArray)/ArrayBuffer/[SharedArrayBuffer](https://develop- er.mozilla.org/en-US/docs/Web/JavaScript/Reference/Global_Objects/SharedArrayBuffer), the byte length as reported by .byteLengthis returned.

Parameters

string:
string
| Buffer
| ArrayBufferView
| ArrayBuffer
| SharedArrayBuffer

A value to calculate the length of.

optional
encoding: BufferEncoding = 'utf8'

If string is a string, this is its encoding.

Return Type

number

The number of bytes contained within string.

Back to top