Skip to content

sindresorhus/string-width

Folders and files

NameName
Last commit message
Last commit date

Latest commit

Jun 30, 2024
ac09208 · Jun 30, 2024

History

65 Commits
Jan 22, 2024
May 9, 2017
Dec 15, 2018
Jul 18, 2017
Jul 18, 2017
Oct 28, 2023
Jun 30, 2024
May 6, 2023
Apr 16, 2021
Jun 30, 2024
Oct 28, 2023
Jun 30, 2024

Repository files navigation

string-width

Get the visual width of a string - the number of columns required to display it

Some Unicode characters are fullwidth and use double the normal width. ANSI escape codes are stripped and doesn't affect the width.

Useful to be able to measure the actual width of command-line output.

Install

npm install string-width

Usage

import stringWidth from 'string-width';

stringWidth('a');
//=> 1

stringWidth('古');
//=> 2

stringWidth('\u001B[1m古\u001B[22m');
//=> 2

API

stringWidth(string, options?)

string

Type: string

The string to be counted.

options

Type: object

ambiguousIsNarrow

Type: boolean
Default: true

Count ambiguous width characters as having narrow width (count of 1) instead of wide width (count of 2).

Ambiguous characters behave like wide or narrow characters depending on the context (language tag, script identification, associated font, source of data, or explicit markup; all can provide the context). If the context cannot be established reliably, they should be treated as narrow characters by default.

countAnsiEscapeCodes

Type: boolean
Default: false

Whether ANSI escape codes should be counted.

Related