打造高效前端工作环境 - tmux
打造高效前端工作环境 - tmux
前言
现在前端开发可不容易啊,先打开个VIM,然后再打开个lite-server,一不小心写个ES2015还要打开个gulp来做预编译,如果能把这么多个窗口放在一个工作台上那就好了。咦,tmux不就专干这事的吗?
tmux入门
安装sudo apt install tmux
tmux的C/S架构
服务端(Server), 1个服务端维护1~N个会话; 会话(Session), 1个会话对应1~N个窗口; 窗口(Window), 1个窗口对应1~N个窗格; 窗格(Pane),vim、bash等具体任务就是在窗格中执行。
1.进入tmux
在shell中执行tmux
就会自动创建一个匿名会话、窗口和窗格,而窗格内正在运行着另一个shell程序,这时我们可以像平常使用shell一样来工作。而tmux真正的威力在于对会话、窗口和窗格的管理,但在此之前我们要先了解开启魔法的阀门——快捷键前缀(prefix)。
2.快捷键前缀(prefix)
tmux为使自身的快捷键和其他软件的快捷键互不干扰,特意提供一个快捷键前缀,默认为Ctrl
+b
。因此当我们输入任何tmux快捷键前必须先输入Ctrl
+b
。
由于快捷键前缀是可以重置的,因此后文将以<prefix>
来指代快捷键前缀。
3.操作Pane
创建(通过分割当前pane实现)
<prefix>
"
,水平分割当前pane
<prefix>
%
,垂直分割当前pane
关闭
<prefix>
x
,删除当前pane
跳转
<prefix>
<up-arrow>
/<down-arrow>
/<left-arrow>
/<right-arrow>
, 通过上下左右方向键跳转到对应的pane
<prefix>
;
,跳转到上次激活的pane
<prefix>
o
,跳转到下一个pane
<prefix>
q
,显示各pane的编号,并输入编号跳转到对应的pane
修改尺寸
<prefix>
+alt
+<up-arrow>
/<down-arrow>
/<left-arrow>
/<right-arrow>
, 通过上下左右方向修改当前pane的高宽
缩放
<prefix>
z
,缩放当前pane
其他
<prefix>
{
,将当前pane移动到最左边
<prefix>
}
,将当前pane移动到最右边
<prefix>
!
,将当前pane转变成window
4.操作Windoiw
创建
<prefix>
c
,创建window
重命名
<prefix>
,
,重命名当前window
注意:由于tmux默认会根据当前pane执行的程序来改变window名称,因此需要在~/.tmux.conf
中加入set-option -g allow-rename off
来固化window名称。
关闭
<prefix>
&
,关闭当前window
跳转
<prefix>
n
,跳转到下一个window
<prefix>
p
,跳转到上一个window
<prefix>
0
...9
,跳转到对应的window
其他
<prefix>
:swap-window -s 2 -t 1
, 调转编号为2和1的两个window的次序
5.操作Session
<prefix>
s
,显示所有会话
<prefix>
$
,重命名
<prefix>
d
,脱离当前会话
<prefix>
:kill-session
,关闭当前会话
<prefix>
(
,跳转到上一个会话
<prefix>
)
,跳转到下一个会话
tmux进阶
1.细抠Session操作
我们为前端开发环境和后端开发环境分别创建两个Session来独立管理,那么我们就可以灵活地在两个Session间穿梭,并且可以分别和前端、后端开发人员协同工作,下面我们看看相关的命令吧。
$ tmux
或 <prefix>
:new
, 创建匿名Session
$ tmux new -s mysession
或 <prefix>
:new -s mysession
, 创建名为mysession的Session
$ tmux kill-session -t mysession
,关闭mysession会话
$ tmux kill-session -a
,关闭所有会话
$ tmux ls
,显示所有会话信息
$ tmux a
,附加到最近一个会话
$ tmux a -t mysession
,附加到会话mysession
2.多个panes输入同步
<prefix>
+ :setw synchronize-panes
这个功能在通过ssh维护多台服务器时十分有用!
3.复制粘贴
通过tmux我们可以通过纯键盘操作实现跨pane的复制粘贴。首先在~/.tmux.conf
文件中添加setw -g mode-keys vi
,启用vi键盘方式(hjkl
方向键,/?nN
搜索)操作buffer内容。
进入复制模式,<prefix>
[
开始选择,<Spacebar>
选择结束并将内容复制到新的buffer,<Enter>
取消选择,<Esc>
从buffer_0粘贴到光标位置,<prefix>
]
可见复制的内容均暂存在buffer中,而tmux也提供直接操作buffer的命令给我们.
<prefix>
: show-buffer
,显示buffer_0的内容
<prefix>
: capture-pane
, 保存当前pane的内容
<prefix>
: list-buffers
, 显示所有buffer内容
<prefix>
: choose-buffer
, 选择buffer并粘贴
<prefix>
: save-buffer buf.txt
, 保存buffer内容到but.txt
<prefix>
: delete-buffer -b 1
, 删除buffer_1的内容
4.美化状态栏 默认的tmux样式有点丑,而https://github.com/gpakosz/.tmux这个配置则为我们提供漂亮状态栏.
深入Layout
内置Layout
tmux为我们内置了5种布局类型
even-horizontal
,从左至右平均分布所有pane
even-vertical
,从上至下平均分布所有pane
main-horizontal
,最上方的pane为主工作区,其余pane位于最下方且从左至右排列
main-vertical
,最左边的pane为主工作区,其余pane位于最右边且从上至下排列
tiled
,从上至下,从左至右平均分布所有pane
对于main-horizontal和main-vertical布局而言,我们还可以设置主工作区的尺寸
# .tmux.conf
set-window-option -g main-pane-width 100
set-window-option -g main-pane-height 100
自定义Layout
其实更多的时候,我们工作区的布局远比内置的复杂。如下左上角为编辑区,右上角为UnitTest回显,最下面是REPL。 这时我们就要先调整好window内所有pane的尺寸,然后脱离当前session,获取当前window的布局信息了。
tmux list-windows
将最后一个]
前的内容复制到tmuxinator的yml配置中的layout那,注意pane数量要和layout的布局信息数据一致。
总结
尊重原创,转载请注明
- TensorFlow从1到2 - 5 - 非专家莫入!TensorFlow实现CNN
- JetBrains Rider 破解 (ideaIU等等开发工具都通用)
- python中的小魔法(一)
- 由问题入手,步步爬出Python中赋值与拷贝的坑
- python爬取链家租房之获得每一页的房屋信息地址(持续更新)
- python使用正则表达式
- python在租房过程中的应用
- python爬虫反爬取---设置IP代理自动变换requests.get()中proxy的IP
- 【译】TensorFlow实现Batch Normalization
- 关于Python语言规范你需要知道的一些小tips
- R语言可视化——REmap(路径图)
- python面向对象
- 字符串hash入门
- R语言数据处理——数据合并与追加
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- c++STL之函数对象(仿函数)
- c++STL容器之map容器
- c++STL容器之使用list容器对自己定义的数据类型进行排序
- c++STL容器之queue容器
- c++STL容器之stack容器
- c++STL容器之vector容器
- c++STL容器之string容器
- AWS(Amazon Linux 2 AMI)在线迁移到腾讯云
- 2020-08-26:裸写算法:树的非递归先序遍历。
- TypeScript手记(一)
- Codeforces Round #665 (Div. 2)
- MONGODB 加索引 大内存 与连锁思维
- 3分钟短文|Laravel 使用like匹配字符串的用法示例
- 3分钟短文|Laravel命令行调用控制器方法,你会几个?
- 3分钟短文 | Laravel 给所有视图追加公共数据