schangxiang@126.com
2025-09-19 0821aa23eabe557c0d9ef5dbe6989c68be35d1fe
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
# string-width [![Build Status](https://travis-ci.org/sindresorhus/string-width.svg?branch=master)](https://travis-ci.org/sindresorhus/string-width)
 
> Get the visual width of a string - the number of columns required to display it
 
Some Unicode characters are [fullwidth](https://en.wikipedia.org/wiki/Halfwidth_and_fullwidth_forms) and use double the normal width. [ANSI escape codes](https://en.wikipedia.org/wiki/ANSI_escape_code) 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
 
```js
const stringWidth = require('string-width');
 
stringWidth('古');
//=> 2
 
stringWidth('\u001b[1m古\u001b[22m');
//=> 2
 
stringWidth('a');
//=> 1
```
 
 
## Related
 
- [string-width-cli](https://github.com/sindresorhus/string-width-cli) - CLI for this module
- [string-length](https://github.com/sindresorhus/string-length) - Get the real length of a string
- [widest-line](https://github.com/sindresorhus/widest-line) - Get the visual width of the widest line in a string
 
 
## License
 
MIT © [Sindre Sorhus](https://sindresorhus.com)