schangxiang@126.com
2025-09-18 49a51c068d62084bc4c3e77c4be94a20de556c4a
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
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
# ansi-escapes [![Build Status](https://travis-ci.org/sindresorhus/ansi-escapes.svg?branch=master)](https://travis-ci.org/sindresorhus/ansi-escapes)
 
> [ANSI escape codes](http://www.termsys.demon.co.uk/vtansi.htm) for manipulating the terminal
 
 
## Install
 
```
$ npm install ansi-escapes
```
 
 
## Usage
 
```js
const ansiEscapes = require('ansi-escapes');
 
// Moves the cursor two rows up and to the left
process.stdout.write(ansiEscapes.cursorUp(2) + ansiEscapes.cursorLeft);
//=> '\u001B[2A\u001B[1000D'
```
 
 
## API
 
### cursorTo(x, [y])
 
Set the absolute position of the cursor. `x0` `y0` is the top left of the screen.
 
### cursorMove(x, [y])
 
Set the position of the cursor relative to its current position.
 
### cursorUp(count)
 
Move cursor up a specific amount of rows. Default is `1`.
 
### cursorDown(count)
 
Move cursor down a specific amount of rows. Default is `1`.
 
### cursorForward(count)
 
Move cursor forward a specific amount of rows. Default is `1`.
 
### cursorBackward(count)
 
Move cursor backward a specific amount of rows. Default is `1`.
 
### cursorLeft
 
Move cursor to the left side.
 
### cursorSavePosition
 
Save cursor position.
 
### cursorRestorePosition
 
Restore saved cursor position.
 
### cursorGetPosition
 
Get cursor position.
 
### cursorNextLine
 
Move cursor to the next line.
 
### cursorPrevLine
 
Move cursor to the previous line.
 
### cursorHide
 
Hide cursor.
 
### cursorShow
 
Show cursor.
 
### eraseLines(count)
 
Erase from the current cursor position up the specified amount of rows.
 
### eraseEndLine
 
Erase from the current cursor position to the end of the current line.
 
### eraseStartLine
 
Erase from the current cursor position to the start of the current line.
 
### eraseLine
 
Erase the entire current line.
 
### eraseDown
 
Erase the screen from the current line down to the bottom of the screen.
 
### eraseUp
 
Erase the screen from the current line up to the top of the screen.
 
### eraseScreen
 
Erase the screen and move the cursor the top left position.
 
### scrollUp
 
Scroll display up one line.
 
### scrollDown
 
Scroll display down one line.
 
### clearScreen
 
Clear the terminal screen. (Viewport)
 
### clearTerminal
 
Clear the whole terminal, including scrollback buffer. (Not just the visible part of it)
 
### beep
 
Output a beeping sound.
 
### link(text, url)
 
Create a clickable link.
 
[Supported terminals.](https://gist.github.com/egmontkob/eb114294efbcd5adb1944c9f3cb5feda) Use [`supports-hyperlinks`](https://github.com/jamestalmage/supports-hyperlinks) to detect link support.
 
### image(input, [options])
 
Display an image.
 
*Currently only supported on iTerm2 >=3*
 
See [term-img](https://github.com/sindresorhus/term-img) for a higher-level module.
 
#### input
 
Type: `Buffer`
 
Buffer of an image. Usually read in with `fs.readFile()`.
 
#### options
 
##### width
##### height
 
Type: `string` `number`
 
The width and height are given as a number followed by a unit, or the word "auto".
 
- `N`: N character cells.
- `Npx`: N pixels.
- `N%`: N percent of the session's width or height.
- `auto`: The image's inherent size will be used to determine an appropriate dimension.
 
##### preserveAspectRatio
 
Type: `boolean`<br>
Default: `true`
 
### iTerm.setCwd([path])
 
Type: `string`<br>
Default: `process.cwd()`
 
[Inform iTerm2](https://www.iterm2.com/documentation-escape-codes.html) of the current directory to help semantic history and enable [Cmd-clicking relative paths](https://coderwall.com/p/b7e82q/quickly-open-files-in-iterm-with-cmd-click).
 
 
## Related
 
- [ansi-styles](https://github.com/chalk/ansi-styles) - ANSI escape codes for styling strings in the terminal
 
 
## License
 
MIT © [Sindre Sorhus](https://sindresorhus.com)